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This book is written for the student who has had some 
exposure to data processing systems and who is inter- 
ested in learning to program and operate the ibm 
1440 Data Processing System. It is assumed he has some 
knowledge of computers and programming acquired 
either by having satisfactorily completed the ibm Basic 
Computer Systems course or an equivalent course; or 
through actual but limited experience in programming. 

Before studying the material in this book, the student 
should know the meaning of terms such as: actual 
codes, symbolic codes, input, output, core storage, ad- 
dress modification, indexing, compiler, block diagram- 
ming, source program, object program, record layout, 
binary-coded decimal — terms defined in the Basic Com- 
puter Systems course. 

The present book contains Part 1 which through the 
generous use of examples covers most aspects of pro- 
gramming the 1440 Data Processing System. It is in- 
tended as a supplement to classroom instruction in the 
IBM 1440 Basic Programming Course and its contents 
therefore closely parallels subjects covered in the 1440 
course. 

Chiefly, these subjects are the Autocoder (pro- 
grammer's) language, the techniques of programming, 
and the system in general. The book will be repub- 
lished in the future to include Part 2 which will 



explain those details one must know to operate the 
computer and to test one's program. 

Questions to test comprehension follow each section. 
Answers to the questions will be found in the Appendix 
at the back of the book. The student's ability to com- 
plete these test questions indicates readiness to proceed 
to the next section. Upon successfully completing Part 
1, the student will be able to write his own programs 
for the 1440 in Autocoder language. 

Each section in this book builds upon the previous 
section. Therefore the student will find it to his advan- 
tage to study the material and to complete the exercises 
in the order presented. Students with considerable pro- 
gramming experience on other systems may wish to re- 
view the questions and problems to determine at which 
point they will begin their study. 

The programming examples represent the author's 
solutions to the problems. The student may find solu- 
tions that differ from the author's. This is possible, for 
seldom is there only one acceptable solution. Look 
upon the author's solutions simply as a guide. 

Additional reference material covering the subjects 
described in this book may be found in the Systems 
Reference Library for the ibm 1440 Data Processing 
System and in the ibm 1440 Autocoder (Preliminary 
Specifications) Systems Bulletin, 
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Section 1 



Components of the 1440 Data Processing System 

Before directing our attention to programming the ibm 
1440 System, we will describe the 1440 components, the 
characteristics of core storage, and the capabilities and 
capacities of the system. This background is essential 
to learning to program the system. 

Every data processing system has various compo- 
nents. These are classified as input devices, output de- 
vices, and combination input/output or processing de- 
vices. The data to be processed by the system is known 
as input because it is entered into the system through 
an input device. The data already processed leaves the 
system through an output device and therefore is known 
as output. 

In the 1440 System, input and output data can be in 
typewritten form, or in the form of punched cards or 
magnetized spots on disks. Output in the form of a 
printed report is further possible. 

Processing in the 1440 is performed by the ibm 1441 
Processing Unit. The 1440 combination input/output 
devices are the ibm 1442 Card Read-Punch, the ibm 1311 
Disk Storage Drive, and the ibm 1447 Console. The 
IBM 1443 Printer is an output device only. Figure 1 
shows the complete system. To understand the func- 
tions of the components and the part they play in the 
complete data processing operation, let us examine 
each unit individually. 

1441 Processing Unit. The 1441 provides the pro- 
grammer with control over the other components of the 
system. It contains the logic as described by its stored 
program and sufficient storage to perform its functions 
among which are the arithmetic operations. In sum- 
mary, then, the three functions of the 1441 unit are: 
(1) Control, (2) Storage, and (3) Arithmetic. 

1442 Card Read-Punch. The 1442 provides the sys- 
tem with input from punched cards and output in the 
same form. 

1443 Printer. The 1443 is used to print high-volume 
output. 



1311 Disk Storage Drive. The 1311 utilizes disk packs 
to provide storage for large amounts of output. The 
output stored in the disk packs becomes input to the 
system. 

1447 Console. The 1447 provides external control 
over the 1440 Data Processing System. It can be 
equipped with a typewriter for keyboard input to the 
system and also for use as a low-volume output printer. 

The relationship of the 1441 Processing Unit to the 
other components of the system is shown in Figure 2. 
The arrows in the figure indicate the direction in which 
data moves from component to component, as directed 
by the processing unit. They show that: 

1. Data can be read from the card in the read-punch 
into the processing unit. From this unit the data 
can be moved as output to disk storage, or to the 
printer, or to the console printer, or to the card 
read-punch, or to any combination of these, as 
required 

2. Input data from disk storage can be read into the 
processing unit and moved from there as output 
to the printer, or to the console I/O printer, or 
to the card read-punch, or to disk storage, or to 
any combination of these, as required 

3. Input data keyed in at the typewriter can be read 
into the processing unit and moved from there as 
output to the card read-punch, or to disk storage, 
or to the printer, or to the console I/O printer, 
or to any combination of these, as required. 



IBM 1441 Processing Unit 

The IBM 1441 Processing Unit has provision for from 
4,000 to 16,000 positions of core storage, in increments 
of 4,000. Each position is capable of storing an alpha- 
betic, numerical, or special character. Characters are 
coded in binary-coded-decimal form. When we discuss 
core storage in a later section, we will have more to say 
about BCD coding. 
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Figure 2. Flow of Data through 1440 System 



Each position of core storage is addressable; that is, 
may be addressed by a program instruction. The data 
in the location addressed may be used by the computer 
in performing an arithmetic operation or may be 
moved to or from the addressed location. Variable 
length fields as in the 1440 allow greater use and flexi- 
bility in storing data and these variable fields can be 
handled by most program instructions. The program 



instructions are stored within the unit to perform the 
operations of input/output, arithmetic, and logic. 

IBM 1442 Card Read-Punch 

Card reading and punching functions are provided in 
one unit and have a single card path. The cards are 
read or punched, proceeding serially from column 1 to 
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column 80. This diagram shows the path of the card 
through the read-punch. 



Reading 
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Hopper 
Card 
Capacity 
1200 



Stacker 2 
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on 
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Note: Stacker Capacity 
1300 Cards 



The card must pass the reading station before it can be 
punched. Cards are read at the reading station — col- 
umn by column — by means of a solar sensing unit, con- 
sisting of twelve solar cells, one for each punch position 
in a card column. 




Solar Cells 



As each column is read, the character is converted from 
card code to its binary-coded-decimal representation 
and is stored in core storage. Any area in core storage 
may be used to store the card data as determined by a 
stored program instruction. 



The 1442 Card Read-Punch is available in two 
models: Model 1 is equipped with one card stacker 
and Model 2 with two card stackers to allow card selec- 
tion. The second stacker is available with the Model 1 
as a special feature. A comparison of the card reading 
and punching speeds for the two models is shown in 
the following table. 

Operation Model 1 Model 2 

Reading only 300 cpm 400 cpm 

Reading and then: 
Punching first 10 

columns 180 cpm 270 cpm 

Punching first 20 

columns 130 cpm 210 cpm 

Punching first 30 

columns 103 cpm 172 cpm 

Punching first 40 

columns 84 cpm 146 cpm 

Punching first 50 

columns 62 cpm 112 cpm 

Punching first 80 

columns 50 cpm 91 cpm 

At these card speeds, a minimum of 75 milliseconds 
of calculating time is allowed for the Model 1 between 
the reading and punching of each card, and 55 milli- 
seconds for the Model 2. 

Two 1442 Card Read-Punches can be attached to 
the system. This configuration allows the card reading 
function and card punching function to be performed 
on separate units, thus providing additional flexibility 
as the application requires. 



IBM 1443 Printer 

A single, stored program instruction can cause up to 
120 positions of core storage to be read out of storage 
and printed. Therefore, the instruction or instructions 
to assemble a complete Une of printing within an area 
in storage should precede the print instruction. 

The standard character set for the printer comprises 
52 characters, each printable in all 120 printing posi- 
tions. Two different 52 character sets, designated Type 
Fonts A and H, are available. A listing of the special 
characters associated with Type Fonts A and H follows: 
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Each has the 26 letters of the alphabet, the 10 num- 
erals, and 16 special characters. 

Note: The numbers at the head of each column are 
the card codes for the special characters. 

Type Font A mounted on a single type bar is the 
standard character set. The type bar is operator inter- 
changeable, i.e., the operator can remove a type bar of 
a particular font and replace it with a type bar of a 
different font. 

A character set is repeated several times on a type 
bar. During printing, the type bar travels on a hori- 
zontal plane. When the character on the type bar 
matches the character desired in the print position, 
printing occurs. All positions are printed in this man- 
ner. 

The rated speed of a Model 1 printer equipped with 
the 52-character set is 150 lines per minute. This speed 
includes a period of 24 milliseconds for calculating 
time. 

In addition to the 52-character set, a 63-character set, 
a 39-character set, and a 13-character set are available 
as special features. These sets also are operator inter- 
changeable. Their rated printing speeds are: 





Model 1 




(lines per 


Set 


minute) 


13 character 


430 


39 character 


190 


63 character 


120 



At these speeds, 24 milliseconds is allowed for calcu- 
lating. 

In addition to the 120-position printing line, a 144- 
position printing line is available. 

Normally, each application prescribes its own format 
for printing a form. To position a form in its prescribed 
format, a separate tape must be prepared. This tape, 
working in conjunction with the stored program, con- 
trols the carriage that positions the form for printing. 



IBM 1311 Disk Storage Drive 

As many as five disk storage drives are available to the 
1440 Data Processing System. On these drives can be 
mounted individual disk packs with a storage capacity 
of 2,000,000 alphameric characters per disk. In this 
way there can be made available to the system, con- 
tinually and at any one time, a total of 10,000,000 



characters of data. The disk packs can be removed by 
the operator and replaced with others, in effect provid- 
ing the system with unlimited storage. 

Another feature of the disk packs is their interchange- 
ability. A disk pack from one disk drive can be inter- 
changed with one from another disk drive, either in 
that same system or in another 1440 system. 

The replaceable disk pack offers both unlimited se- 
quential storage and random storage. Records for a 
particular application can be stored sequentially or 
randomly or both randomly and sequentially. Retrieval 
in either manner is also possible. Random records can 
be retrieved sequentially or sequential records can be 
retrieved randomly. However, the latter method re- 
quires that the programmer provide a table lookup. 

The disk pack weighs approximately ten pounds and 
consists of six 14-inch disks. Each disk surface with 
the exception of the upper surface of the top disk and 
the lower surface of the bottom disk is used as a re- 
cording surface. Therefore, ten readable surfaces are 
provided by a disk pack. 
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Mounted vertically on a disk drive is a comb-type 
access assembly with five access arms on each of which 
there are two read-write heads. The access assembly is 
used to position the read-write heads on the disk sur- 
faces (Figure 3) . Each of the access arms, with its two 
read-write heads, moves between the bottom surface of 
a disk and the top surface of the next lower disk, and 
is capable of reading or writing data on both of these 
surfaces. 
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100 
Cylinders 




As the disk revolves, a read- write head passes over 
a circular band on the surface of the disk — this is 
called a track. The ten tracks that are exposed simul- 
taneously to the ten read- write heads as the disk pack 



revolves are referred to as a cylinder^ because of their 
cylindrical appearance when represented as in the il- 
lustration. A cylinder, in this sense, is a quantitative 
concept rather than a physical component. It may be 
considered to be a three-dimensional entity compris- 
ing a particular track on each of the ten disk surfaces. 
There are 100 cylinders, numbered 00 to 99, in a disk 
pack (Figure 3) . The read-write heads can be posi- 
tioned at any one of these 100 cylinders. 

Each track is divided into 20 equal-size sections 
known as sectors. Every sector contains a 5-digit address 
and provides storage for either 90 characters of data 
with word marks or 100 characters of data without word 
marks. 

All sectors are addressable. Therefore a disk pack 
provides 20,000 addresses that may be accessed for read- 
ing or writing of data. This figure is arrived at in the 
following way: 

20 addresses X 10 tracks = 200 addresses 

per track per cylinder per cylinder 

200 addresses X 100 cylinders = 20,000 addresses 
per cyl- per 

inder disk pack 



Comb-Type 
Access Assembly 



e 




Disks 



Figure 3. Read- Write Heads Positioned at one of the 100 Cylinders 
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The 5-digit sector address which precedes each sector 
in a disk pack is called the disk sector address. The 
sector addresses are in numerical sequence within the 
track, cylinder, and disk pack. Figure 4 shows the layout 
of sector addresses for each track of cylinder 00 on the 
number disk drive. The sector-address ranges for the 
five disk drives are: 



Disk Drive 
Number 


Address Range 



1 
2 
3 
4 


00000-19999 
20000-39999 
40000-59999 
60000-79999 
80000-99999 



The average time required to seek a sector address 
is 250 milliseconds; the maximum time, 400 millisec- 
onds. A seek is the operation of positioning the read- 
write heads (access assembly) at a specific cylinder on 
a disk drive. For each seek, the access assembly must 
first retract to its home position (outside cylinder 00) 
and then move to the selected cylinder. A Direct Seek 
(special feature) is available which eliminates the 
re turn- to-home motion of the access assembly, thus 
reducing access time. With this special feature, the 
average access time is 150 milliseconds; the maximum 
time, 250 milliseconds. 



Addresses 00000-00199 




DJrecfion of Rotation 



Figure 4. Layout of Sector Addresses by Track for Cylinder 00 



IBM 1447 Console 

The 1447 Console is offered in two models: the Model 1 
is equipped with keys, lights, and switches only. The 
panel on this console allows the operator to: 

1. Start and stop the computer. 

2. Initiate the loading of a program into core storage. 

3. Display data from core storage. 

4. Restart the program after an error condition has 
caused it to stop. 

5. Alter instructions in core storage. 

The operation of the keys, lights, and switches on the 
1440 will be covered in Part 2 of this book. 

The Model 2 has, in addition, a Console I/O Printer. 
The printer provided by this feature can be used to 
enter data into core storage and to type out data from 
core storage. In addition, the operator can use the 
printer to initiate an inquiry, that is, to request that a 
certain disk record be printed. Because inquiries are 
under control of the stored program, the programmer 
must provide the inquiry test instructions and sub- 
routines necessary to get the record. 

Any of the 63 characters that are permissible in core 
storage can be printed out by the Console I/O Printer. 
Its character rate is 14.8 characters per second. Nor- 
mally, this printer is used to type error messages, ex- 
ception notices, or inquiries. 

Core Storage 

In describing the 1441 Processing Unit, we mentioned 
that the 1441 uses core storage to store data and instruc- 
tions. At this point, we will describe some character- 
istics of core storage such as coding, organization, and 
the addressing scheme, for a knowledge of these char- 
acteristics will strengthen the programmer's foundation. 

Character Coding 

Characters are represented in core storage in binary- 
coded-decimal form. Each character is composed of a 
unique combination of bimry digits, or bits as they 
are called; one character to one position in core stor- 
age. A position in core storage has a 7-bit structure, 
which is designated CBA 8421. 

The four rightmost bits (8421) are called numerical 
bits, because they correspond in a way to the numerical 
punches in card coding. Similarly, the BA bits corre- 
spond to the zone punches in card coding and are called 
zone bits. The C bit is the check bit that is generated 
within the system to give each character an odd or even 
count of bits, depending on whether the system uses 
odd or even parity. 

The 1440 system uses an odd number of bits and 
the parity check consists of checking for this odd con- 
figuration of bits. It is an internal self-checking device 
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of the computer for providing it with a high degree of 
assurance that it is operating correctly. 

Table 1 shows the card codes and corresponding 
binary-coded-decimal form of the 64 characters (this 
includes a blank character) that can be entered into 
core storage. Note that the letters A- 1 have zone bits 
AB, corresponding in a way to zone punch 12. Simi- 
larly, the letters J-R have zone bit B, corresponding to 
zone punch 1 1 . The letters S-Z have zone bit A, corre- 
sponding to zone punch 0. The numbers 0-9 are repre- 
sented by the numerical bits, 8-4-2-1, alone. 

In addition to the seven bits which we have discussed, 
there is an eighth bit, called the word mark (WM) , 
that is associated with each position of core storage. 
This bit defines the leftmost position of a data field and 
the first position of an instruction. Usually, the word 



mark is placed in the leftmost position of a data field. 
When it is present in a position of storage, the bit 
combination in that position is adjusted to maintain 
an odd number of bits. For example, the letter A, when 

a word mark (J[4) is present, appears as: 

W 
M 



C BA 1 



or when the word mark is absent, as: 
BA 1 

The bit configuration of each character shown in 
Table 1 is adjusted in the same manner. Zone bits or 
numerical bits of a character do not change: the con- 
figuration of the character changes only with respect 
to the G bit, which is either added or not added. 



Table 1 . Character Codes in Ascending Sequential Order 
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Organization and Addressing 

Instructions must be placed in core storage before they 
can initiate operations. The data that is to be processed 
must also be placed in core storage to be operated upon. 
Therefore, both data and instructions are in core stor- 
age during operation of the program. The allocation of 
areas in core storage for input data, output data, 
constants, and work areas is determined by the pro- 
grammer. Figure 5 shows how 1000 positions of storage, 
numbered 000-999, can be subdivided into areas. None 
of the areas is fixed in storage; i.e., the print area, for 
example, is not always assigned positions 001-120; it 
could just as easily have been assigned positions 801- 
920. 

The Autocoder system of programming provides 
certain instructions to aid the programmer in defining 
areas. If these instructions are used, storage assignment 
is automatically performed by the Autocoder processor 
while the object program is being assembled. Auto- 
matic assignment of storage is described in greater 
detail in Sections 2 and 3. 



Each position of core storage is addressable by a 
unique 3-digit mixed alphameric address code. For the 
most part the programmer need not concern himself 
with these codes when programming in the Autocoder 
language. The coded addresses and their decimal 
equivalents for the first 4000 positions of core storage 
appear in Figure 6. Decimal numbers 

through 15999 

are used when coding a program in Autocoder lan- 
guage. When the object program is assembled, these 
numbers are converted into 3-digit machine language 
codes. 

The first one thousand 3-character addresses are 
coded in machine language as numbers between 000 
and 999. Addresses of 1000 and over are handled in a 
special manner to fit into the 3-character format. The 
numerical bits of the three characters represent the 
units, tens, and hundreds position of the address. The 
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Figure 5. Allocation of Areas in Core Storage 
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Coded Addresses in Storage 


Equivalent 




Decimal 
Addresses 


3-Character Addresses 


000 to 999 


No zone bits 


~000 to 999 


1000 to 1099 




+00 to 499 


1100 to 1199 




/OO to /99 


1200 to 1299 




SOO to S99 


1300 to 1399 




TOO to T99 


1400 to 1499 


A-bit ^ 


UOO to U99 


1500 to 1599 


using zone 


VOO to V99 


1600 to 1699 




WOO toW99 


1700 to 1799 




XOO to X99 


1800 to 1899 




YOO to Y99 


1900 to 1999 




_Z0O to Z99 


2000 to 2099 




~ !00 to !99 


2100 to 2199 




J 00 to J99 


2200 to 2299 




KOO to K99 


2300 to 2399 




LOO to L99 


2400 to 2499 


B-bit 


MOO toM99 


2500 to 2599 


using 1 1 zone 


NOO to N99 


2600 to 2699 




*O00 to099 


2700 to 2799 




POO to P99 


2800 to 2899 




QOO toQ99 


2900 to 2999 




„R00 to R99 


3000 to 3099 




"?00 to ?99 


3100 to 3199 




AOO to A99 


3200 to 3299 




BOO to B99 


3300 to 3399 




COO to C99 


3400 to 3499 


A-and B-bits ^ 


DOO to D99 


3500 to 3599 


using 12 zone 


EOO to E99 


3600 to 3699 




FOO to F99 


3700 to 3799 




GOO toG99 


3800 to 3899 




HOO to H99 


3900 to 3999 




_ 100 to 199 


* Letter O followed by zero zero | 



Figure 6. Core Storage Address Codes 



zone bits B and A o£ the leftmost character are given 
values of 2 and 1, respectively, and are used to represent 
the thousands position of the address for addresses up 
to 3,999. The address 

0123 



is represented in storage as 

-Hi 
-^4 



whereas the address 



is represented as 



2123 



XL"i 
IDlLCl 

J±XIj 



Parity (C) bits are not shown. 

Addresses over 3,999 are handled by using the zone 
bits of the rightmost character similarly. The B and A 
bits of this character are given values of 8 and 4, re- 
spectively, and are combined with the bits from the 
leftmost character to represent the thousands and ten 
thousands positions of the address. 

Bit Values 

Leftmost Zone Rightmost Zone 

B=2 B=8 

A=l A=4 

Therefore, the address 

5486 
is represented in core storage as 



B 
A 

8 
4 
2 
1 


"Tin 

A| 1 Al 

-]8f 1 

-T| -f4\ 

1 'f2i 

:lTj 



The coded address range for addresses 4,000 through 
16,000 is shown at the top of the following page. 



Components of the 1440 Data Processing System IS 



Equivalent 
Decimal 
Address 

4000 to 4999 

5000 to 5999 

6000 to 6999 

7000 to 7999 

8000 to 8999 

9000 to 9999 

10000 to 10999 

11000 to 11999 

12000 to 12999 

13000 to 13999 

14000 to 14999 

15000 to 15999 



Zone Bits over 
Hundreds Char- 
acter Position 

No zone bits 
A bit (zero zone) 
Bbit (11 zone) 
A, B bits (12 zone) 

No zone bits 
A bit (zero zone) 
Bbit (11 zone) 
A, B bits (12 zone) 

No zone bits 
A bit (zero zone) 
B bit (11 zone) 
A, B bits (12 zone) 



Zone Bits over 

Units Character 

Position 

A bit (zero zone) 

A bit (zero zone) 

A bit (zero zone) 

A bit (zero zone) 

Bbit (11 zone) 

Bbit (11 zone) 

Bbit (11 zone) 

Bbit (11 zone) 

A, B bits (12 zone) 

A, B bits (12 zone) 

A, B bits (12 zone) 

A, B bits (12 zone) 



3-Character 
Address Range 

00 ^= to 99Z 

4=04= to Z9Z 

!04: to R9Z 

?04= to I9Z 

00! to 99R 

^=0! to Z9R 

!0! to R9R 

?0! to I9R 

00? to 991 

4rO? to Z9I 

!0? to R9I 

?0? to 191 



o 



Section 7. Questions 

1 . High-volume printed output is normally obtained 
from 

a. 1443 Printer 

b. 1447 Console I/O Printer 

2. If input data is used as output— as, for example, 
when listing from cards— does this input data go 
through the processing unit? 

3. Can a record which is stored in the processing 
unit be stored on the disk, be printed out, and 
be punched into a card? 

4. How many alphabetic characters can be stored in 
4,000 positions of storage? 

5. Which statement is true? 

a. A card must pass the punching station before 
it can be read. 



b. A card must pass the reading station before it 
can be punched. 

6. What are three of the fundamental functions of 
the processing unit? 

7. How many characters with word marks can be 
stored in one disk sector? How many characters 
without word marks? 

8. What is the range of sector addresses on cylinder 
00 of the second disk drive? 

9. What are the five digits that precede each data 
sector called? 

10. Are all positions of core storage addressable? 

11. Besides identifying the first position of an instruc- 
tion, what is another function of the word mark? 



o 
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Introduction to Programming 



Section 2 



c 



In Section 1 we described the components of the ibm 
1440 Data Processing System and the characteristics 
of core storage. In this section, we will concern our- 
selves with the fundamentals of programming and the 
methods of programming the 1440 itself. This will in- 
volve an exploration of the purpose of programming 
and its functions in data processing. Finally, we will 
point out the programming details that the program- 
mer must pay attention to, the form that he will use 
in writing a program, and the method he will employ 
to describe data. 



Purpose of Programming 

Data processing by any method requires that an orderly 
procedure of steps or operations be followed. This pro- 
cedure must be translated step-by-step into a series of 
instructions, arranged in logical sequence, which the 
computer can perform. The series of instructions is 
known as a program. 



f uircfion of the Programmer 

There are two major tasks a programmer must perform 
to develop a program: 

1. To establish the requirements of the problem and 
the requirements of the solution. 

2. To write the program for the computer to follow. 

The first task, a systems study, requires that the pro- 
grammer define the problem in the broad sense: choose 
the machine or computer configuration; and establish 
the format or layout of report forms, records, and cards. 

The second task requires that, preliminary to the 
actual writing of the program, the programmer define 
the problem in a step-by-step analysis and work out the 
logic of the program in the documented form of block 
diagrams or the recently developed decision tables or 
by using both. Either form of documentation is ac- 
ceptable: both are immeasurable aids. 

In the programming examples presented in this book, 
we have provided both forms of documentation, leaving 



it up to the student to choose the one he is more fa- 
miliar with or the one he prefers. 



Language of Programming 

Problems for the computer can be coded in actual ma- 
chine language (absolute) if the programmer knows 
the language of the particular computer; however, even 
beyond the problems of the machine language itself, 
the method is often difficult in other respects: in assign- 
ing storage locations, in correcting or modifying pro- 
grams, and in cross referencing within a program. For 
these reasons, other languages have been developed. 
We shall use the language called Autocoder for it most 
nearly eliminates these difficulties. The use of Auto- 
coder language almost completely precludes the pro- 
grammer's need to know how the computer operates on 
each and every instruction or how the data is repre- 
sented in storage. Therefore, we will delay describing 
machine functions until we have presented the prin- 
ciples of programming. 

In summary, the advantages of using Autocoder 
rather than machine language for our program are: 

1. We can use symbolic addresses in the coded pro- 
gram in place of actual addresses. 

2. We can replace actual codes in the coded program 
with mnemonic operation codes that are de- 
scriptive and more meaningful. 

3. The processor, while it is translating our symbolic 
source program into an actual (machine lan- 
guage) object program, edits our source program 
and uncovers coding errors. 

Here is a specific set of actual machine language 
instructions. 



M % G 1 


A 1 


2 R 


A A 2 5 


A 3 


5 


A A 3 


A 3 


5 


M A 3 5 


D 3 


5 


M % G 1 


D 1 


2 P 
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If we write them in Autocoder language, they will 
look like this: 







Edit 


Operation 


Operands 


Pass 


R 


1, RDAREA 




A 


AFIELD, SUM 




A 


BFIELD, SUM 




MLC 


SUM, PCFIELD 




P 


PCAREA 





Each line represents one instruction. These instructions 
direct the computer to do the following: 

No. 1 tells it to Read a card into the storage read 
area which is symbolized by 
"rdarea." 
No. 2 Add amount of "afield'' to amount 

"SUM." 

No. 3 Add amount "bfield" to amount 

"sum'' 
No. 4 Move the amount "sum'* to its 

punching location symbolized by 



PCFIELD. 



No. 5 



Punch a card from the data at the 
punch area symbolically represented 

by "PCAREA." 

From this example, we can see that operands of an 
instruction are written immediately adjacent to one 
another and are separated only by a comma, a require- 
ment of the Autocoder language. 

These Autocoder instructions must be transcribed 
into punched cards, for it is the cards that become the 
actual input (source program) that the processor will 
assemble as an object program to be run by the com- 
puter. The object program produced by the Autocoder 
processor contains its own loading instructions; that 
is, it has instructions for automatically loading itself 
into its assigned areas of storage when it is entered into 
the 1440 system. 

We may want to edit our source program to uncover 
coding errors and to be able to correct these errors 
before proceeding to produce the object program in 
card form. The edit pass produces an edited program 
listing. With this listing, we can correct our mistakes, 
again process the corrected input cards (the source 
program) , and produce the final object program in 
both card and list form. 



Source Program 



1440 

System 

(Using Autocoder Processory 



Assembly 
Pass 



Source Program 




1440 

System 

(Using Autocoder Processor) 



Object Program 



Program 
Listing 



The program listing gives the original Autocoder 
instructions, the assembled instructions, the error mes- 
sages, and the assignment of storage for instruction 
and data. This listing is used later to debug the pro- 
gram. Debugging is testing the program for errors until 
all errors (bugs) are eliminated. Figure 7 depicts the 
steps thus far described. 

In our description of Autocoder language, we showed 
some operations and operands and referred to these as 
program instructions. No mention was made of any 
particular format in which these instructions should be 
written because the purpose of the example was to 
illustrate the difference between machine language and 
Autocoder language. If we wish to write these Auto- 
coder instructions properly for machine use, we will 
have to write them in the format prescribed by the 
Autocoder coding sheet. 



o 
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( Keypunch j 



X 



Source 
Program 



1440 

Data 

Processing 

System 



Object 
Program 



a 



Over-alt 
System Study 
and 
Documentation 



Detailed Documentation, 

Decision Tables 

and 

Block Diagrams 



Program Writing, 

Using 

Autocoder 



Conversion to a 
Source Program 



Processing on 
1440 Data Processing 
System To Produce 
Object Program and 
Listing 



Listing 



Figure 7, Steps in Preparing an Object Program 



Use of Autocoder Coding Sheets 

The programmer enters all program entries on the 
Autocoder coding sheet (Figure 8) . The column num- 
bers on the coding sheet indicate the punching format 
for all input cards in the source deck. Each line of the 
coding sheet is punched into a separate card. The func- 
tion of each field of the coding sheet is explained, as 
follows: 



Page Number (Columns 1-2) 

This entry provides sequencing for coding sheets. 

Line Number (Columns 3-5) 

This entry provides sequencing for lines within a cod- 
ing sheet. The first 25 lines are prenumbered 01-25, The 
source program cards must be in ascending line num- 
ber order when they become input to the system. 

Label (Columns 6-15) 

A symbolic label can have as many as six alphameric 
characters. The first letter of the label is always written 
in column 6; the character contained in this position 
must be alphabetic. 

Operation (Columns 16-20) 

Mnemonic operation codes are written in this field, 
starting in column 16. Table 2 shows the Autocoder 
mnemonics for declarative operations, imperative op- 
erations, and control operations. Declarative operations 
are described as being those that are used to reserve 
areas and to store constants. Imperative operations are 
those that are converted, one for one, into instructions 
or program steps in the object program. Control opera- 
tions are those that enable the programmer to exercise 
some control over the assembly process. 

Operand (Columns 21-72) 

The operand field in an imperative instruction can 
contain: 

1. The actual or symbolic address of the data to be 
acted upon, as directed by the command in the 
operation field. (Note: a label that appears as an 
operand is considered a symboL) 

2. The actual data to be operated upon; data in this 
form is referred to as a literal 

3. The address constant, i.e., the symbol which repre- 
sents the actual 3-character address that is assigned 
to the corresponding label. (A plus or minus sign 
must always precede an address constant so that 
the processor can distinguish it from a symbolic 
address.) 

Operands in Autocoder language are always sepa- 
rated by commas. The statement that follows demon- 
strates the use of commas. This instruction causes data 
specified by the A operand (actual address 3101) to be 
added to the data specified by the B operand (actual 
address 140) . 



Label 

6 tS 


Operatic^ 


OPERAND 

21 25 30 35 40 45 SO 


-r ■ ^ 


A . .. , 


3,1.0,1.. .1,4.0 


1 , , . 




-^ 1 1 > t 1 1 i- 1 1 1 1 < 1 1 1 1 1 * 1 1 1 1 1 1 1 1 1 ^ 1 
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IBM 

Program 

Programmed by- 
Date 



INTERNATIONAL BUSINESS MACHINES CORPORATION 

IBM 1401, 1410, AND 1440 DATA PROCESSING SYSTEMS 

AUTOCODER CODING SHEET 



Identification i_ 



Page No.U-J of 
I 2 



Line 

3 5 


Label 
6 15 


Operation 
16 20 


OPERAND 

21 25 30 35 40 45 50 55 60 65 70 


0, 1 , 


1 
_, , . , . 1 . . ^.. 






2 










































































0.3 










































































0,4. 












































































0,5 














































































0,6 














































































0,7 














































































0,6 














































































0,9 


















































L 




























1,0 














































































1 , 1 














































































1,2 














































































',3 














































































1 ,4 














































































1,6 














































































l<^ 














































































'|7 














































































',8 


























■n 




















































>,9 
















































1 






























2,0 














































































2, 1 














































































2,2 














































































2,3 














































































2,4 














































































2,5 
















































1 


L_ 


L.II 












UJ 






LJ 






























































III 
















































































































1 j 












































































1 1 




















































































1 1 












, 


1 


















^^ 


^_. .^ . 











o 



G 



Figure 8. Autocoder Coding Sheet 



Note that the first and second operands of an impera- 
tive statement are referred to as the A and B operands. 
A third operand is called the d-modifier. The next state- 
ment is an example of a statement that contains all 
three operands. 



6 


Label 

15 


Operotion 

16 20 


2t 25 


30 35 


40 


OPERAND 

45 {f9 


, , , , . 1 . . , 


B.CE. 


E,N.T.RYA,. 


.S,WI.T,GH.,2 , 








, , . . 





This instruction, when assembled, tests the storage 
location equivalent to switch for a digit 2 and branches 
to the location equivalent to entrya for the next in- 
struction, provided switch contains a 2. The digit 2 is 
the d-modifier. Only certain Autocoder operations re- 
quire a d-modifier. They are indicated by J in Table 2. 

The programmer can include a remark or comment 
anywhere in the operand field, if he leaves at least two 
blank (nonsignificant) spaces between the remark and 
the operand. If he added a comment to the previous 
statement, it would appear as follows: 



6 


Label 

15 


Operation 
16 20 


21 25 


30 35 


40 


OPERAND 

45 50 55 60 65 70 


1 ■■■■ 


BCE. 


ENTRYA,. 


.S,WITC,R..2. 




.SM .FQR A .DJ.QI.X ^. .AND RRANeH,._ 


1 
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Table 2. Autocoder Mnemonic Operation Codes 



n 






Mnemonic 




Mnemonic 




Mnemonic 




Operation 


Description 


Operation 


Description 


Operation 


Description 


Code 




Code 




Code 




DECLARATIVE OPERATIONS 


BCE 


Branch If Character Equal + 


WDCO 


Write Disk with Sector Count Overlay 


DA 


Define Area 


DC 

DCW 

DS 

DSA 

EQU 


Define Constant 

Define Constant with Word Mark 

Define Symbol 

Define Symbolic Address 

Equate 


BSS 

C 

BIN 

BBE 

INPUT/OUTPUT TYPE 

W 

WS 

WCP 


Branch If Sense Switch On + 

Compare 

Branch If Indicator On + 

Branch If Bit Equal* + 

Write a Line 

Write a Line and Suppress Spacing 

Write Console I/O Printer 


WDCOW 

RDTR 
RDTRW 

RDTA 
RDTAW 

WDTR 
WDTRW 


Write Disk with Sector Count Overlay 

and Word Marks 
Read Disk Track Record* 

Read Disk Track Record with 

Word Marks* 
Read Disk Track Record and Address* 

Read Disk Track Record and Address 

with Word Marks* 
Write Disk Track Record* 

Write Disk Track Record with Word 
Marks* 


IMPERATIVE OPERATIONS 


ARITHMETIC TYPE 




A 


Add 


RCP 


Read Console i/O Printer 


WDTA 


Write Disk Trock Record and Address* 


D 
M 
S 


Divide* 

Multiply* 

Subtract 


R 
P 
PS 


Read to Group Mark with a Word Mark 
Punch and Feed 
Punch and Stop 


WDT AW 


Write Disk Track Record and Address 
with Word Marks* 


ZA Zero and Add 
ZS Zero and Subtract 
DATA CONTROL TYPE 


LU 

MU 
WDC 


Load Unit* 
Move Unit* 
Write Disk Check 


MISCELLANEOUS TYPE 

CC Control Carriage + 

CS Clear Storoge 


MCE 
MCS 
MLC 
MLCWA 

MLNS 


Move Characters and Edit 

Move Characters and Suppress Zeros 

Move Characters to A or B Word Marie 

Move Characters and Word Marie 

from A-field 
Move Numerical Portion of Single Character 


WDCW 

SDL 

SDLW 

SDE 

SDEW 


Write Disk Check with Word Marks 

Scan Disk Low, Equal* 

Scan Disk Low Equal with Word Marks* 

Scan Disk Equal* 

Scan Disk Equal with Word Marks* 


CW 

H 

MA 

NOP 

SAR 


Clear Word Mark 

Halt 

Modify Address* 

No Operation 

Store A Address* 


MLZS 


Move Zone Portion of Single Character 


SDH 


Scan Disk High, Equal* 


SBR 


Store B Address* 


MRCM 

LOGIC TYPE 

B 

BAV 

BC9 

BCV 


Move Characters to Record Mark or 
Group Mark with a Word Mark 

Branch Unconditional 
Branch on Arithmetic Overflov^ 
Branch on Carriage Channel 9 
Branch on Carriage Channel 12 


SDHW 

SD 

RD 

RDW 

RDT 

RDTW 


Scan Disk High, Equal with Word 

Marks* 
Seek Disk 

Read Disk Sector(s) 

Read Disk Sector (s) with Word Marks 

Read Disk Track Sectors with Addresses 

Read Disk Track Sectors with Addresses and 
Word Marks 


SS 

sw 


Select Stacker* 
Set Word Mark 


CONTROL OPERATIONS | 


CTL 


Control 


BE 


Branch on Equal Compare (B = A) 


WD 


Write Disk Sector{s) 


END 


End 


BH 


Branch on High Compare (B > A) 


WDW 


Write Disk Sector(s) with Word Marks 


EX 


Execute 


BL 


Branch on Lov^ Compare (B < A) 


WDT 


Write Disk Track Sectors with Addresses 


LTORG 


Literal Origin 


BU 


Branch on Unequal Compare (B ^ A) 


WDTW 


Write Disk Track Sectors with Addresses and 


XFR 


Transfer 


BLC 
BPB 

BW 


Branch on Last Card (Sense Switch A) 
Branch Printer Busy 
Branch on Word Mark 


RDCO 
RDCOW 


Word Marks 
Read Disk with Sector Count Overlay 

Read Disk with Sector Count Overlay and 
Word Marks 


JOB 
ORG 
SFX 


Job 

Origin 

Suffix 


BWZ 


Branch on Word Mark or Zone ^ 










* Indica 


tes a Special Feature 










+ Indica 


tes that the programmer must supply d -modifier in 


Autocoder Statement 









A comment in no way affects the assembled machine 
language instruction, however it does appear on the 
program listing opposite the assembled instruction. 

In preparing a program, it is necessary to determine 
the constants and storage areas that are needed, and to 
define them. Usually this step is completed before the 
program is written; however, it may be accomplished 
as the program is being written. 

Symbolic Assignment of Core Storage 

In Autocoder language, assignment o£ symbolic names 
(labels) to data fields, constants, or instructions re- 
lieves the programmer of the problem of keeping track 
of actual storage locations. The programmer should 
assign names that are meaningful. For example, he 
might label a 6-position field reserved for withholding 
tax as WHTAX. A word of caution— once he has assigned 
this label, he must be careful not to assign it to two 
different fields. 

The Autocoder processor program assigns the actual 
storage locations as it produces the object program. 
The Processor has a location assignment counter for 
this purpose. The counter is set at 210 at the start. 
Each time the processor assigns an area, the counter 
is incremented by the number of positions in that area. 
The last number in the assignment counter is the ad- 
dress of the area. 

A 4-position constant (for example, abgd) is assigned 
the address 213, provided the assignment counter was 
set at 210 when the statement defining the constant 
was encountered. Subsequent statements will be as- 
signed storage in the order in which they are encoun- 
tered. The Autocoder language contains control in- 
struction that allow the programmer to preset the 
counter to a particular address or to change the setting 
of the counter during assembly. Thus, the programmer 
can start the assignment of storage at any address he 
specifies. 

There are no permanently assigned areas within core 
storage except for storage positions 0087-0099 which are 
used by the Indexing feature (a special feature) . Areas 
for input and output are assigned by the processor to 
areas which it selects (unless specified otherwise) and 
with one restriction. The leftmost position of an area 
reserved for printing on the 1443 Printer must be an 
address that ends with 01 (XXOl) . 

The Autocoder instructions used to create constants 
and to reserve areas in core storage are known as 
Declarative operations. Here we describe some of the 
ways to write these instructions and show how the 
processor operates upon them. 



Storage Assignment with Declarative Operations 



DCW Define Constant with Word Mark 

This operation is used to create alphameric or 
numerical constants, address constants, or 
blank areas, in core storage as part of the object 
program. A word mark is automatically added 
to the leftmost position of the created field. 

A numerical constant can be given a plus or 
minus value by preceding it with a + or — sign 
in the statement in which it appears. Numeri- 
cal constants take the following form 



o 



Label 


Operation 

l& 20 


OPERAND 

21 25 so 95 40 45 50 


CQN.ST.lI , , , 


DCW . 


+ .1.2.3.4 


C,QN,ST,2i , , , 


DCW . 


- 5.6.3.2 


CQN.ST.a! . , . 


DCW , 


12.3.4.5.6,7 


1 . , , 







where the constant itself may be any number of 
characters. The address that is associated with 
the label of the constant will be that of the 
rightmost position of the constant itself. An 
alphameric constant or a blank constant can 
also be defined; these constants must be pre- 
ceded and followed by an "at" (@) sign. 



Label 

6 15 


Operarion 

16 20 


OPERAND 

21 25 50 55 40 45 


C0.N,S.T.4| , , 


DCW . 


@E.RR.aR, .ME,S.S AGE. ,1,@ 


CQN.ST.sl , , 


DCW , 


a J,A.N,U.A,RY. ,2,8,., ,1,9,6,2,@ 


CQ N.ST. el . . 


DCW . 


@ @ 









CONST6, which is a 9-position blank field, can 
also be defined by the following statement; 



Label 

6 15 


Operarion 


OPERAND 

2) 25 30 55 40 45 SO 


CQN.ST.el , , , 


DCW , 


#9 


1 








where the # symbol precedes the number that 
tells how many blank storage positions are to 
be defined. 

DC Define Constant 

This operation is the same as the DCW opera- 
tion except that a word mark is not added by 
the processor to the leftmost position of a field 
being defined. The statements are written in 
the same manner as DCW statements. 



c 



20 



DS Define Symbol 

This operation is used to reserve an area of core 
storage and to associate a label with the ad- 
dress of that area. Unlike the DCW or DC op- 
eration, the DS operation does not load any 
data as part of the object program. 



label 

6 (5 


Operafion 
le 20 


OPERAND 

21 25 30 36 40 45 50 


A,C.C,U.M. 1 , , , 


D,S, 


10 










A field within a field is called a subfield. mo 
and DAY are subfields of the date field. In the 
example, the rightmost position of the subfields 
is written in column 21. Word marks are not 
generated by the processor for subfields. 

A word mark is automatically generated in 
the leftmost position of each field, provided 
there are two numbers in the operand field and 
these are separated by a comma. The data gen- 
erated by the statement appears in the object 
program as: 



o 



In the example given, the number of positions 
to be reserved is ten, as specified by the value 
of the number in the operand field. 



DA Define Area 

The DA operation is used to define an area for 
input or output and to place a group mark 
with a word mark in a position immediately 
to the right of the area. This operation is un- 
like the declarative operations described so far, 
where the address associated with the label is 
the rightmost position of the area. The address 
of a label associated with a DA statement is the 
leftmost position of the area. Entries following 
the DA entry are used to define fields and sub- 
fields that fall within the limits of the area. For 
example, the statements 



Line 

5 5 


Label 


operation 
16 20 


OPERAND 

Zl ZS 30 35 40 45 


OJ L 


I,T,E,M . 1 , , , 


PA . , 


1X,5,3,, ,G, , I.,A.Y,0,U,T, ,0,F, ITEM, .CAUD, 


2 


c.CDf; . ! , , . 




1 . ,1 


0,3 


DA.T.E. .1 




2,5 i;i,E,L,D 


0,4 


MQ , , . 1 . . , 




3 Rn,R.F,TEI.n 


0,5, 


DAT, ,.!,., 




5 S,U,B,F,I.E,LD 


0,6, 


SLMND. 1 , , . 




6.-8 


0,7, 


CLASS . ! . , , 




9,13 


0.8, 


U.P, ,..!.,. 




1 .4 ., .1 fl 


0,»^ 


0,T.Y3, . 1 , , . 




2,0., .2.2 


'0, 


O.T,Y,B.O. 1 , , , 




2 3,, 2.5 


1 , 


A.MT, ,.;.,, 




2 15,. 3.1 


1,2, 


SVBS ..{... 




^>2,. .3,7 


1,5, 


i ,T,M,N,o. ; . , , 




p.8„ .4,5 ,,,,,,, 


1,4, 


Q.T.Y, ,.;,,, 




4 ,6 „ ,4,8 


1,5, 


b.u.s^p . ; , , 




4,9.. ,5,3 


1,6. 









reserve a 63-position storage area followed by 
a group mark with a word mark. The first posi- 
tion of the area becomes the first field, the sec- 
ond through fifth positions become the second 
field, etc. 



bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbM 

where b represents a blank position with a 

word mark, b represents a blank position, and 

G 

M represents a position which contains both 

a group mark and word mark. The address of 
the rightmost position of each field is associated 
with its corresponding label. 

The following statements show how three 
similar areas, each followed by a record mark, 
can be defined. 



Label 

6 15 


Operation 
16 '^ 20 


21 25 


30 


35 


40 


OPERAND 

45 


r.e,c,b.lk! , , . 


DA . . 


3X.5.+ „.G 


NAME, . 1 , , , 




l.,2 , , , 


DATE, . 1 . , , 




3,.. 5 ..,..., 


1 , . , 1 , , ■ , 





These statements generate 

G 

bbbbb4=bbbbb4=bbbbb =}= M 

as a part of the object program. The number 
in column 21 in the operand field specifies the 
number of times the fields should be repeated. 



EQU Equate 



This operation is used to assign a label to an 
actual or a symbolic address. It allows the pro- 
grammer to assign different labels to the same 
storage location and to refer to the storage loca- 
tion by either name. No storage is reserved and 
no data is loaded as part of the object program 
when this operation is used. 



Label 

5 IS 


Operation 


21 25 


30 


55 


40 


OPERAND 

45 


I N D I.V . 1 , , , 


EQ,U, , 


MAN.N,n 


1, , 
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Suppose, for example, that the symbol manno 
is assigned the address 1234 by the processor. 
When the equ operation is encountered, the 
label iNDiv will be assigned the same address 
(1234) . 



The following statement equates the label 
NETPAY to an actual address. 



Label 

6 15 


Operotion 

16 20 


OPERAND 

21 25 30 95 40 45 


ne.tpa.y! , 


EQU 


8,0 


; , 1 1 1 j_L 




, . , , 



o 



Section 2. Questions 

1. What are the two major tasks of a programmer? 

2. What is the name of the programming language 
we use in writing instructions for the 1440 system? 

3. Area definition statements are used for which of 
these? 

a. to instruct the machine to perform arithmetic. 

b. to assign storage areas for data. 

c. to control the processor function. 

d. to write instructions for the computer. 



In this example the address of the constant as- 
sociated with the label date will be: 

a. the address of the leftmost position of the 
constant. 

b. the address of the rightmost position of the 
constant. 

7. What is the difference in the result of these two 
statements? 



Label 

6 15 


Operotiori 

16 20 


21 25 SO 35 


RE, AD, in! . , , 


D,A . , 


1X8.0 


. -j-.i 1 1.-L » ■ -L.. 







If the statement shown above is entered in a pro- 
gram, will subsequent statements using the symbol 
readin be addressing: 

a. the leftmost position of the area reserved? 

b. the rightmost position of the area reserved? 



5. 



Label 


Operation 


21 25 


30 


95 


D.A.T.E, . 1 . . . 


D.QW 


@,D.E,C, .1,® 


1 







Label 

6 IS 


OperaHoq 

16 20 


;i 


25 


90 95 40 


D,AT.E, . 1 , , . 


D,C,W 


^, 


. .D,E.C. 


.@ 




D,AT,E, . 1 , , , 


DC, . 


a 


. .D.KC, 


.C , , ._. 











c 



8. Correct the following statements. 



Label 
6 ts 


Operation 

16 20 


21 25 30 35 40 


Cp,N.S,T,l! , , 


,D,CW 


@,E.RRO.R. .I,I,S.TmG @ 


4,T,H, ,.',,,, 


D,C,W. , 


12,345.6, . , , 










.DATE. 1 . . . 


D,C , 


&. .DE.G .9, .a 












A. , . , 


29.62. .7,2.0, , 










R.EAD,rjfll . , , 


DA, , . 


1 . .8 ,0 










DA.TE. , 1 . . . 


D,C,W, , 


fi^P£BR.UA.R|Y 

























c 
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Programming a Basic Job 



Section 3 



Since we are now familiar with the programming tools 
that are used in planning and coding a job, we will 
proceed to program a basic job. In this job, two factors 
are to be read from a card, added together, and the 
total punched into the same card. 

Figure 9 shows the format of the input cards. Field B 
is to be added to field A and punched into field C. 
Whenever possible, the field or fields that are to be 
punched should be located near the column-1 end of 
the card. This arrangement minimizes the time re- 
quired to punch each card and thereby maximizes card 
throughput. The term card throughput refers to the 
number of cards per minute that can be processed by 
the system for any given job. 

Block diagram, Figure lOA, and decision table. 
Figure lOB, initiate the program with the reading of a 
card. 



The second step is finding the total of A plus B and 
punching the result. The third step is a test for last 
card. The fourth step is a branch back to the first 
action (read a card) . These four steps are repeated 
for each card until all cards are processed. 

Twelve Autocoder statements (see Figure 11) consti- 
tute the coded program. The first three statements de- 
fine the core storage area into which the card is read; 
the next two statements define the area from which the 
card is punched; and the remaining seven statements 
are the imperative statements that make up the pro- 
gram instructions. This ordering of the statements is 
only one possibility; the imperative statements could 
have been written or could have appeared first and 
been followed by the five declarative statements. 



o 



C = 

OQCOOOQOO 

13 3 4 5 6 7 8 3 

n n 11 1 11 

22222 2222 
33333333 3 
444444444 
555555 5 55 
6 66666666 
777777777 



999999999 

12 3 4 5 6 7 8 9 



+ B 



000000 

10 U 12 13 14 15 16 17 
11111111 

222222 22 
33 33333 3 
44444444 
555 55 5 5 5 
66666666 

7 7777777 

8 8 8 88888 
99989999 

!fj 1! 12 1j 14 15 le 17 



OOGOOOO 

18 19 20 21 22 23 ?4 
1 1 1 1 I 1 1 

22222 22 
3333333 
4444444 
5 5 55 555 
666666 6 
7777777 



99999 9 9 

It IB 20 i I 2? 25 2-1 



Q G Q 

25 26 27 28 29 30 3) 32 33 34 3G 36 37 3& 39 40 41 V/ 43 44 45 4fi 4,' 4C 45 50 51 52 5j 54 5^ 56 57 58 53 60 61 f.2 6^ 64 65 ft ^-Z CS 69 70 n 12 73 ?4 75 7fi 77 78 79 30 

1 1 1 11 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 n 11 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 n 1 1 n 1 1 1 1 1 1 11 1 

22222222222222222222 2 2222222222 222 22 2 22 22 2222222 2222 2222 
33 33 3333333 333333 33333 3 33333333 3 3 3 333 3 3 3 3 3 33 33 3 33 333333 3 
44444444444444444444444444444444444444444444444444444444 
5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 
6666 666 666666 6666666666 66666 8686 6 6 666 666 6 666 6 6 6 666666 6 6 6 

imiiiinniiininiii nninninii 11 11 mil mmiiii 

8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 9 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 
9999999 999999 999999 9999 99999 999 9 3 999999 99 99 99 9 9 99999999 9 

25 26 27 28 2;i n 31 32 23 34 35 36 37 3C 39 40 41 42 43 44 45 «6 47 4« te 5f 51 52 53 54 55 56 ^7 58 5P 60 61 62 63 64 6b of V f>8 69 70 Ti n 73 74 75 76 77 78 79 8G 



Figure 9. Card Format for A 4- B =^ C 
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1 f 








Read Card 












'f 








Crossfoot 
A + B = C 








1 


^ 








Punch Card 














No ^XW\Yes 


Halt 




^^ar 


ly^ 





Figure lOA. Block Diagram for A + B = C 



A detailed analysis of the coding sheet is given in 
Figure 1 1 . Line 01 of the coding sheet reserves 24 posi- 
tions in storage and one additional position for a group 
mark with a word mark. 

Reserving an Area for Card Reading, The 

number of positions the programmer re- 
serves must equal the highest-numbered card 
column to be read. In this example, the 
highest-numbered card column is 24 (see 
Figure 9) . The label rdarea will be assigned 
the address equivalent to the leftmost posi- 
tion of the read area when the program is 
assembled. 

Lines 02 and 03 assign the labels afield and bfield 
to the addresses of the A and B factors, respectively. 



** START 
























^. 


t 


















1 
I 




r 


















2 IrEADCARD 


X 




















3 iSET C = A 


X 




















1 +B 


X 




















4 Ipunchcard 


X 




















5 IsTOP 




X 


















1 
_.. ,__i 























o 



Figure lOB. Decision Table for A + B = C 



In effect, the two fields within the read area are defined 
and word marks are placed in the leftmost positions of 
the fields to identify their limits. Because the processor 
initiates assignment of storage, the read area will start 
in storage position 210 and will extend into higher- 
numbered positions, as shown: 

A Field B Field 



bbbbbbbbb'bbbbbbbb'bbbbbbbM 

t " ■ " 

210 

Line 04 reserves a 9-position punch area labeled 
pchara and sets a group mark with a word mark in the 
position to the immediate right of the area. 



Reserving an Area for Card Punching, An 

area reserved for punching must contain the 
number of positions equal to the highest- 
numbered card column to be punched. The 
position to the right of this area must con- 
tain a group mark with a word mark. 



c 



Line 
3 5 


Label 

6 15 


Operotion 
16 20 


OPERAND 

21 25 30 35 40 45 50 55 60 65 


0.1, 


R,D,A,R,EAi . , , 


DA, , 


1X2.4. .G I3}E;f. I.N.E. .R.E.AD, AREA 


2 


af.ieldI 












10.. .1,7. 












0,3 


Bj.i^hjy\ 












1,8.. .2,4 












0,4. 


p.charaI 








DA, 






1?^.9..,G. 








EJUF.I^.E, .P.UNCH AREA 




0,5. 


C,F.If:LX>l 














1...9 












0,6 




START, 1 








R, , 






1,,.R.D,AR,E,A 








READ .A .CARD, .I.N.TO. .R,E,A,D 


.AR.E.A. . 


0.7 
















ZA, 






AF.IP.I^D., ,C,F,IELX) 








CRQS.S.F.O.O.T 




0,8 
















A, , 






B.F,IE.LD,.,C,EIE,LD 












0,9 
















p;s, 






1,. .P,C,HA,R,A 








HUNCH .FJRPM, P.U.N,C,H. .A^E.A 




'.0 






















H.AT.T 








TEST, .F.O.R .LAST, CA^J). . , 




r , 1 
















B, . 






START 












',2 




HALT 












H, . . 












END 




r,3 






L J 














J ,,i_j._.i 1 ,1, I.. ..J 1. 1 1 1 


^ 








1 1 1 1 1 1 L 



Figure 1 1 . Coding Sheet for A + B = C 
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Line 05 assigns the label cfield to the address 
equivalent to the rightmost position of the field to be 
punched. A word mark is set in the leftmost position of 
this field, thus identifying its limit. 

After assembly, the combined read and punch areas 
reserved by the first five statements will appear as: 



A Field B Field 



C Field 



bbbbbbbbbWbbbbfe€bbb^M^bbbbbbbl3M 

t 

210 

Line 06 initiates a card reading operation that causes 
card columns 1-24 to be read into core storage, starting 
at position 210. The first group mark with a word mark 
encountered terminates the transfer of data to storage. 



Card Reading Operation, In a card reading 
operation, the A operand (1) is a constant 
that specifies card reading is to be performed 
by the 1442 Read-Punch, Unit Number 1. 
If the constant (A operand) contained a 2, 
the card reading operation would be per- 
formed instead by Unit Number 2 (special 
feature) . The symbol rdarea specifies the 
address in core storage where the storing of 
data starts (position 210) , i.e., where the 
data from card column one is stored. We 
will want to branch back (return) to this 
instruction from another point in the pro- 
gram, therefore we must give it a label. The 
label START causes the address of the instruc- 
tion to be saved for further use during the 
assembly of the object program. 



Line 07 is a ZA statement which resets to zeros the 
field in the punch area containing the C factor and 
then adds the A factor into the cleared area. 



Zero and Add Operation, In a ZA statement, 
the A operand specifies the field to be added 
whereas the B operand specifies the field to 
be cleared (reset to zeros) . Data to be added 
is transmitted, starting with the rightmost 
position. A word mark terminates the opera- 
tion. 



Word Marks in Arithmetic Operations. The A-field 
word mark stops data transfer from the A field. The B- 
field word mark stops the operation and data transfer. 



Therefore, if both fields are of equal length, only the 
B-field word mark must be present. If the A field is 
shorter than the B field, a word mark must be present 
in both fields. 

We will find that this use of word marks is the same 
for all other arithmetic operations with the exception 
of multiply and divide (special features) . In our ex- 
ample, word marks have been set in the leftmost posi- 
tion of the fields by the DA statements. These word 
marks are not erased or affected by an arithmetic op- 
eration. 

Line 08 adds the B factor to the A factor to produce 
the total C. 



Add Operation, In an Add (A) operation, 
the data addressed by the A operand is 
added to the data addressed by the B oper- 
and, digit by digit, starting in the rightmost 
position. The total that is developed re- 
places the data previously stored at the B 
address. 

The use of word marks in an Add opera- 
tion is the same as in the ZA operation just 
described. 



Line 09 initiates a card punching operation. The A 
operand indicates that the punching is to be performed 
by the Read-Punch, Unit Number 1. The B operand 
PCHARA is the address of the leftmost position of the 
core storage area to be punched. 



Card Punching Operation, The A operand 
specifies which Card Punch unit is to be 
used: code 1 for Punch unit, Number 1 and 
code 2 for Punch unit, Number 2. Punching 
starts with the addressed position and con- 
tinues through higher-numbered positions 
until a group mark with a word mark termi- 
nates the operation. Either the PS operation 
code (Punch and Stop) or the P operation 
code (Punch and Feed) can be used to start 
the punching operation. 

If the PS operation code is used, the card 
remains at the punching station after punch- 
ing is completed until the next card is read 
or until a P operation code is given. If the P 
operation code is used, the card after being 
punched is ejected from the punching sta- 
tion into the stacker and another card is fed 
past the reading station to the punching 
station. 
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Line 10 tests the last card indicator by use of a BLC 
operation code. 



Branch on Last Card Operation, The A 

operand (halt) directs a branch to the in- 
struction labeled halt^ if the Last Card indi- 
cator is on. If it is not on, the next sequential 
instruction is executed. The BLC statement 
provides the logical means for ending the 
program after the final card has been proc- 
essed. 



Test for Last Card, In the 1440 system the Last Card 
indicator turns on, when the last card passes the reading 
station, if Sense Switch A is in the on position. In most 
programs the last card test normally follows the series 
of instructions which process the data read from a card. 
In our job, we want to direct the program to halt or 
end when the last card indicator is found to be on. The 
fact that it is on indicates that the last card of the deck 
has been processed and punched. 



Line 11 causes an unconditional branch to the in- 
struction labeled start^ i.e., it causes the program to 
return to the card reading instruction to begin the 
sequence of steps again. 



Branch Unconditional Operation, The B 

operation is used at the end of a series of in- 
structions. It always causes a branch to the 
address of the instruction specified by the A 
operand. 



Line 12 provides the Halt instruction that causes the 
program to end. This statement is labeled so that it 
may be branched to from another point in the pro- 
gram. When the last card condition is sensed (see line 
10 of the coding sheet) , the program branches to the 
Halt instruction. 



Halt Operation, In every program, the pro- 
grammer must provide a Halt (H) instruc- 
tion to stop the computer after it has proc- 
essed the data. No operands are required for 
this operation. 

If the Halt instruction is written with an 
operand, the program will branch, when the 
Start key is depressed, to the address speci- 
fied by the operand. 



Arithmetic Sign Control and Overflow 

Sign Control. Since two of the arithmetic instruc- 
tions. Zero and Add (ZA) , and Add (A) , have been 
described, it is appropriate at this time for us to con- 
sider arithmetic sign control and overflow. 

Algebraic signs of fields within the computer are 
indicated by the zone bits in the rightmost position of 
the fields. 

A positive field may be represented in any one of 
three ways: 

by an A bit only, 

by both A and B bits, 

by no A and B bits. 

For example, a positive 123 may appear in core stor- 
age as: 



I I 



I I A 

T~r-J 
J J_ ' 



tjib:! 

I I Aj 

IlIIj 
_iJ_ ' 
_ L2J1] 



or 



Til 

_L_L ' 

ii_Lil 



A negative field is indicated in one way only: 

by a B bit. 
A negative 123 will appear as: 



~T"I"B] 

-f-l-- 
:r-j:: 

-LJJ 
_ I IM I 
II i LJ 



A field containing all zeros can be positive or nega- 
tive. If a positive zero field and a negative zero field 
are compared by the computer, the computer will 
recognize them as being unequal because the zone bits 
in the units position of the two fields are not alike. 
The programmer, therefore, must take into account 
the bit configuration of positive and negative fields 
when comparing fields that have been added or sub- 
tracted. We will delve deeper into this subject in the 
next section when we describe the Compare operation. 

Overflow. When an arithmetic overflow occurs, the 
zone bits in the leftmost position of the field (specified 
by the B operand) are altered to signify the overflow. 



o 



c 
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For example, a field containing 999 to which a 1 is 
added, thereby causing an overflow, will appear in 
storage as: 

-aI-J-1 

8 Tg I 81 
--I— 1-1 



;ciiiii 



__L1_I 



The overflow has caused an A bit to be set in the left- 
most position. The zone bit configurations associated 
with the first overflow and subsequent overflows are: 



Overflow 
First 
Second 
Third 
Fourth 

Fifth 
Sixth 
Seventh 
Eighth 



Zone Bits 
A bit 
Bbit 

A and B bits 
No A or B bits 

A bit 

Bbit 

A and B bits 

No A or B bits 



Additional overflows repeat the zone bit configura- 
tion of the first four overflows, as shown. In addition 
to the manipulation of the zone bits for overflows, an 
Overflow indicator is turned on when the first overflow 
occurs. Testing the indicator with a Branch instruction 
turns it off. 



Section 3. Questions 

1. When the last card indicator turns on, the last 
card 

a. is at the reading station ready to be read. 

b. is sitting in the card hopper. 

c. is beyond the punching station or in the card 
stacker. 

d. is passing the reading station. 

2. Which Autocoder operation code is used to define 
a punch area in core storage? 

a. BCE 

b. DC 

c. DA 

d. ZA 



3. How many positions of core storage must be re- 
served for reading card columns 30-48? 

4. Which of these numerical digits stored in core 
storage are positive? 

B 

a. A 
2 

b. A 
2 

c. B 
2 

5. In an Add operation where the A field is shorter 
than the B field, 

a. only the leftmost position of the B field must 
contain a word mark. 

b. only the leftmost position of the A field must 
contain a word mark. 

c. both fields must contain a word mark in their 
leftmost positions. 

d. neither field requires a word mark. 

e. both fields must contain a word mark in their 
rightmost positions. 



Line 
s s 


Label 

6 IS 


OperaMon 
16 20 


?i 2S so 


.,.. IS 


t , 


HE. G.I.N. 1 . . , 


R , . 


1 . .RD.AREA, , 








0,2 




ZA . 


A- R 










0.3 




A, 




D-.R 


^ 








0,4, 




A, , 






E...B 


, 








0,5. 




PP 






1. PCHAR.A, . 










0,6. 




B,I^C 






ST.O.P 










0.7, 




B , 






B.E,G.IN 


^ 




^ 




o,e, 


S.T,OP. . 1 . , 


H . 








, 




. 


0,9, 










._ . 1 1. . . 1 j_ . 


,_. 




, , 



In this program a label is given to line 01 so that: 

a. the address of the read area will be assigned 
to the label begin. 

b. the program will have a starting point. 

c. a later program step can branch to the Read 
instruction. 

d. the start of the program can be identified. 
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Programming the Card System 



o 



Section 4 



In Section 3 we saw an example of a program written 
in Autocoder language for a basic job of reading two 
factors from a card and punching the result into the 
same card. In this section we will describe a series of 
Autocoder programs that involve operations with the 
Read-Punch, the Printer and, of course, the Processor. 
These problems illustrate many programming prin- 
ciples and are designed to broaden the student's pro- 
gramming knowledge and ability. 

In the last section, the A operand was used to specify 
the address of a particular field. Likewise, the B oper- 
and was used to specify the address of a second field. 
Henceforth, we will refer to the fields which are as- 
sociated with the A and B operands as the A and B 
fields, respectively. 



Programming Example 1 . 
Detail Printing from Cards 

Detail printing from cards is printing from each card 
as it passes through the Card Read-Punch. All 80 
columns of the card can be read and printed or only 
certain fields may be printed. 

Figure 12 shows the format of the cards to be read 
in our example; those fields marked with a *^ are to 
be printed. Figure 13 shows the order in which the 
fields will appear on the printed line in the listing. 
This listing contains a column headed "invoice 
amount." The invoice amount is not read from the 
card: it is the sum of the discount allowed plus the 
amount paid. The sum (invoice amount) and the 
decimal points and commas that appear in the amount 
columns are generated by the program. 



c 



/Customer No- 



Entry , Date 



Customer Nome 



Entry 
Date 



Day 



Customer Name 



Invoice 
Dote 



Day 



Invoice 
Number 



Customer 
Number 



City 



Trade 
Class 



Sales- 
man 
No 



Mo 



Day 



Discount 
Al lowed 



Amount 
Paid 



000000 

« 9 10 11 12 13 

111111 

222222 
333333 
444444 
555555 
666666 
777777 
888888 
999999 

8 9 to 11 12 13 



0000000000000000 

14 15 16 17 It 19 20 21 22 23 24 25 26 27 28 29 
1111111111111111 



2222222222222222 
3333333333333333 
4 4 4 4 4 >/ 4 4 4 4 4 4 4 4 4 
5555555555555555 
6666666666666666 
7777777777777777 
8888888888888888 
9999999999999999 

14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 



00000 

34 35 36 37 38 
1 1 1 1 1 



22222 
3333,3 
4 4Y44 

55555 
66666 
77777 
88888 
99999 

34 35 38 37 38 



00000 

39 40 41 42 43 
11111 

22222 
333 3,3 
44^44 
55555 
66666 
77777 
88888 



99999 

39 40 41 42 43 



000 

46 47 48 
1 1 1 

222 
333 
444 
555 
666 
777 
888 
999 



000 

49 50 51 
1 1 1 

222 
333 
444 
555 
666 
777 
888 
999 

49 50 51 



00 

52 53 
1 1 

22 
33 
44 
55 
66 
77 
88 
99 

52 53 



00 

54 5S56 
1 1 1 

222 
333 
444 
555 
666 
777 
888 
999 

54 55 56 



00 

59 60 
1 1 

22 
33 
44 
55 
66 
77 
88 
99 

59 60 



oooloo 

63 64 65|66 67 

1 1 111 1 

I 

2 2 2i2 2 

I 

3 3 3i3,3 

4 4Y44 

5 5 5',5 5 



OOOOiOO 

68 69 70 71 172 73 
1 1 1 1j1 1 

22 2212 2 
33 3 3I3J 



444 



f 



6 6 6|6 6 

I 

7 7 7]7 7 

8 8 818 8 

I 

9 9 9i9 9 

62 63 64 65166 67 



5 5 5 515 5 
66 6 6|66 

7 7 7 717 7 

I 

8 8 88|8 8 

I 
9999199 

68 69 70 71 72 73 



0000000 

74 75 76 77 78 79 80 
1111111 

2222222 
3333333 
4444444 
5555555 
6666666 
7777777 
8888888 
9999999 

74 75 76 77 78 79 80 



Figure 12. Card Format for Detail Printing 
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ACCOUNTS RECEIVABLE 














REGISTER 














CUSTOMER 
NUMBER 


CUSTOMER NAME 


INVOICE 
NUMBER 


DISCOUNT 
ALLOWED 


AMOUNT 
PAID 


IN^/OICE 
AMOUNT 






09285 


COVENTRY OIL 


11509 


5.93 


587.02 


592.95 




09285 


COVENTRY OIL 


12292 


9.51 


941.46 


950.97 






21217 


CRESCENT BELT CO 


11511 


3.36 


332.27 


335.63 






21217 


CRESCENT BELT CO 


12263 


1.22 


120.53 


121.75 






29031 


DENNIS MFC CO 


11615 


4.40 


435.72 


440.12 






29031 


DENNIS MPG CO 


11676 


7.22 


715.00 


722.22 






2913^ 


DEPOSIT DIST CO 


09689 


6.45 


638.95 


645.40 






2913^ 


DEPOSIT DIST CO 


11605 


2.72 


268.97 


271.69 






2913^ 


DEPOSIT DIST CO 


12234 


5.59 


553.74 


559.33 






30327 


GENERAL MFG CO 


09352 


11.21 


1,116.03 


1,127.24 




Print 
Positions 


7-11 


16-37 


45-49 


55-60 


63-70 


73-80 





Figure 13. Form Layout for Detail Printing 
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Figure 14A, block diagram, and Figure 14B, decision 
table, give a general description of the program. In 
the description, the program proceeds to assemble a 
line of information for printing, after reading a card. 



to 



Read Card 




Skip to 
Next Form 




Halt 



Figure 14A. Block Diagram for Detail Printing 



The assembled line is printed and a test is made to 
determine if the end of the form (assuming a continu- 
ous form is used) has been reached. If an end-of-form 
condition is indicated, a skip to the first line position 
of the next form must be initiated. After printing of 
one card is completed, the test for last card is per- 
formed. If the Last Card indicator is on, the program 
halts; if it is off, the next card is read and the steps of 
the diagram are repeated. 

The Coding sheets (Figure 16) contain the state- 
ments that make up the program for detail printing 
this example. Line 01 defines the starting address of 
storage assignment. Lines 02-08 define the print area, 
lines 09-14 define the card read area, line 15 reserves a 
work area, line 16 establishes a constant to be used by 
the program, and lines 17-25 and 01-11 (second coding 
sheet) constitute the program itself. 



»* START 






















1 HAS LAST CARD BEEN PROCESSED? 


N 


N 


Y 
















2 ICARRIAGE OVERFLOW INDICATOR ON ? 


N 


Y 


















1 






















3 I READ CARD 


X 


X 


















t 
4 1 PRINT 


x 


X 


















5 1 SKIP TO NEXT FORM 




X 


















6 1 GO TO START 


X 


X 


















7 ]HALT 






X 
















1 

! 


J 
















J 





Figure 14B. Decision Table for Detail Printing 
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»oge 


No 


iQ.li 
1 z 


0f-< 


22 


— 


Line 
3 5 


Label 

6 15 


Operation 
16 20 


OPERAND 

21 25 30 35 40 45 50 55 60 65 70 


1 , 


1 


OR,G. , 


4 0.1, , .B.E,G,I,N. ,T.HE, .A, S, S.IG.N,ME.N,T. ,0,F, ,S.T.O,RA,aE, ,WI,T.H .P,0. S. ,4,0,1, . , 


2 


PRLI.RE 








DA, 




2,x,8.0,,.a , , , .DRFTMR ,P,R.T .N,T, TN ,G. .A,R.E,A. ,,.>.,, 




















0,3 


cusno.lI 












11 .R,TT,R.F.T .E,T.n,S .. .G.TT.S .TiO,M.E,R. .N,TI MB,E.R, , 
























0,4 


c.usn.a.lI 












3,7. . , 


.G.TI,S.T.O,ME,R .N,A,ME . . 




























0.5. 


i>5,vno.lI 












4,9. . , 


T.N.V.O.I.C.E, .N.UMB.ER . 




























0.6. 


D,I,S,CL. 1 












6.0, . , 


D.I.S.GOU.N.T .AL,L,O.WED 




























0,7, 


amt,p.d.lI 












7.0. . . 


A.MO.TT.N,T. ,P,A.T,n 




























0.8, 


'I.NAMT.lI 












8,0, . , 


I ,N,VDJGE. ,AMO.U,N,T. . ; 




























0,9, 


rd,a,r,eaI 








D,A 




l,x.7.3.. 


G nE.RI,N.E, ,C,A,RD. ,R.E AJ3.T .N,G, .AR,E,A. . . 




























',0. 


c.u,s,n,a.cI 












8.. ,2.9. 


F.T.E.T.r),S,..nTLR.TOJVLE,R, ,N.A,ME, . . , 




























r , 1 , 


I.N,V.N,0.C| 












3,4,. ,3,8 


T ,N,V.O.T .C.E. .N.U.MB,E.R, . . 




























',2, 


CUS NpC| 












3,9,, 4 3 


. , , . .C,U,S.T,0.]VTER, .N.UMBER. 




























'>3. 


D,I.S,C,C. 1 












6.3., .6.7 


. , D.T ,S,GO.TT.N,T, ,N.U,MR,E.R. . 




























1 ,4, 


AMXPDC'i 












6,8.. ,7,3 


. , . . AM,0,UN.T. .P.AI.D, . , . . . 




























1 ,5. 


A,C.C.U,]VL I 








D,GW . 


#,6. , . 


1 1 1 1 1 J t 1 1 1 1 1 1 1 !_.. i J 1 i.._.J_ 1 1 1 I 1 J J 1 1 1 1 






1 






















1 .6, 


C,T,R,L,W.Di 








D,C.W . 


(5),t5. f .b.lbiO.. ,tiit),(5l , , , . , , , I , i . 1 1 , , , , . , 




























' ,7. 


S,T.AIl,T 


1 








R, , . . 


1,,.RDAREA READ ,A .CARD 




























t ,8, 




1 








MLG , 


G,TT,S,N,O.G,,.nTT,S.Nn,T. , . , , AS.S E .MR T.E. ,P,R,T N.T ,T..T ,N.E. 




























1,9. 




1 








MLG , 


C,U.SNAC..,CU.SNAI. 




























2,0. 




1 








MLG , 


rN.V,N,O.C..,I.N.V.N,0,L, ,.,.,,...,,. , , . , 




























2, 1, 




1 








MI.GW^CT.R.L.WD.,,DJ.SjCX.. 
























— - 


2,2. 












MCE , 


DI .S.C.C..D,I,SGJL L , ■ 






















2,3, 




1 








MLGW^C,T,R,L,WD .,amt.p,d,l, , . , , , = , . , 






















2,'*, 




1 






MCK , 


A^MTPD.C,,,AM.T.P.D,L ^ . , 




















2,5, 


i 1 iiili.il 


ZiA, , , 


D,I|S,C,CH,Ag;CTiM 1 1 i 1 * ; i 1 i, » . 1 ...1-1 1 i..i 1 . i - ; 1 1 




—I 


-J 




L^ 





o 





































PageNo.iO,2| of 02 
1 2 


— 


Line 
3 5 


Label 

6 15 


Operation 
16 20 


OPERAND 

2r 25 30 35 40 45 50 55 60 65 70 


1 , 


I 


A , . 


AMT,PnG,,,AGGUM , . 


2 


._1 1 L_. J 








MIhQWA 


GT,R,L,W,D„,I.N,AMT,1, 


\ — 1 


I — 1 












0,3 










MCE , 


ACCU.M,.I.NA.MTL . 




-1 












0,4 










1 


GC , 




s 




._J 






J 














0,5, 


, 


.. 1 1 








w , . 




p,rlln,e; . , . 


1 — 1 






1 — 1 


I — 1 


1 — 1 


1 — 1 


P,R.T.N.T, ,A, .LJ,N,E , 










0,6, 












HGV, 




O.FLO, ..... 
















T.E.S.T. .F,Oil. ,GHAN,N,E,L, .T.WE.LVE 










0,7. 












B , , 




L.S,T.qD . , , . 
















R.RA.N.G.H. .T.O, .LS.T.C.D 










0.8, 


0,F,L.O 










ac , 




A 












-I 




SK,T.P, ,T.O. .F.TRS.Ti ,L,TN,E ,N,E,X.T 




F,0,R,M . , , , 






0,9, 


LS.T.C 


A 1 








B,I,C, 




HA.L,T 




-J 












TES.T. ,FQR ,LA,S,T, C,A.RD. . , , , 










1.0, 












R , . 




S,T.A,R,T 


L_J 










I — i 


L_.J 


■RR.A.Nr,,H. .rn. RT,A.R,T, ....... 










1,1, 


HALT 










H , , 




— 1 — I — 1 — J — 1 — 1 — 1 — 1___1 — i 


I — 1 




L— 




^ 






FN,n. PRnr..R,A,M. 









Figure 15. Coding Sheets for Detail Printing 



Line 01 starts the assignment of storage at position 
401 with an origin statement. 



Origin Operation, The ORG statement pro- 
vides the programmer with a means of con- 
trolHng storage assignment. The address 
specified in the operand field is the starting 



address. If this statement were not present 
at the beginning of the program, the proc- 
essor would automatically start assignment 
with position 210. An ORG statement can 
be inserted at any point in a program if 
the programmer desires to assign subse- 
quent addresses beginning at the address 
specified in the operand field. 
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Suppose a field such as customer number appears in 
the read area and the print area. We could use cusno 
as the label for the read area field and cusn for the 
label for the print area field, but we would have to re- 
member which of these we assigned to which and this 
is difficult to do in a large program. Of course, we could 
continually check ourselves by referring to our last use 
of the label but this procedure is time-consuming and 
subject to error. For this reason we use a technique 
that involves a mnemonic suffix to the label. 

Unique Labels with Suffixes, Where the names of 
two or more fields are similar but must be designated 
by unique labels, it is only natural to expect that the 
label associated with each will be similar. For example: 
the field "customer number" which is located in both 
the read and print areas may be expected to have the 
label CUSNO. However, no two fields can be designated 
by one label. 

The customer number field in the read area must be 
distinguishable from the customer number field in the 
print area. By using the technique of adding a c suffix 
for card read and an I suffix for print line to the base 
cusNO^ we develop 

cusNOC for customer number in the read area 
cusNOL for customer number in the print area 

This technique of suffixing can be extended to yield 
other advantages; for once we have established a suffix 
for an area, we can give it to all fields in that area. 
For example, 

CUSNOL for customer number in the print area 
cusNAL for customer name in the print area 
iNVNOL for invoice number in the print area 
DiscL for discount allowed in the print area 

Besides distinguishing one label from the other, the 
common suffix provides an easy clue to, and identifica- 
tion of, an entire group of labels. A single-digit suffix 
has been used in our examples. Two-digit suffixes can 
be used if they are more meaningful or prove more 
descriptive. 

Line 15 causes a 6-position storage area to be re- 
served. A word mark is set in the leftmost position of 
this field. The # symbol precedes the number that in- 
dicates how many blank positions are to be defined. 
The field established by this statement is used in the 
program to accumulate "invoice amount." 

Line 16 defines the 8-position alphameric constant 
that will be used by the program to perform its print 
edit function. The print edit function includes zero 
suppression and the insertion of decimals and commas 
in the amount fields. The alphameric constant must be 



preceded by and followed by an @ symbol. The char- 
acter b is used to indicate blank positions within the 
constant. 

Line 17 causes card columns 1-73 to be read into 
core storage. 

Line 18 is an MLC operation which moves the A- 
field data to the B field. The "customer number" is 
moved from the read area to the print area; the A-field 
word mark governs the move since no word mark was 
set in the B field (print area) . 



Move Characters to A or B Word Mark 
Operation, The A and B operands in an 
MLC operation represent the addresses of 
the respective A and B fields. The data is 
moved, starting with the rightmost digit of 
the field and continuing to the left until a 
word mark is encountered in either field 
(A or B) . Word marks in either field remain 
unchanged. The A-field data remains un- 
changed by the move operation. 



Line 19 causes "customer name" to be moved by an 
MLC operation from the read area to the print area. 
Line 20 causes the "invoice number" field to be moved 
from the read area to the print area. 

Line 21 is an MLCWA operation that moves the data 
from the A field to the B field. The constant (sym- 
bolized in our example by ctrlwd) is set up in the 
print area preliminary to performing an edit instruc- 
tion. 



Move Characters and Word Mark from A 
Field Operation, In an MLCWA operation, 
the A-field word mark is used to terminate 
the movement of data from the A field to the 
B field. Unlike the MLC operation in which 
either word mark terminates the move, in 
the MLCWA only the A-field word mark 
can stop the movement of data. In addition, 
the A-field word mark is transmitted to the 
B field and word marks contained in the B 
field prior to the move are erased. 



Line 22 is an MCE operation for moving data from 
the A field (discount allowed) to the B field and for 
modifying the data by the contents of the B field (con- 
trol word) . This control word was previously set up 
in the print area by line 21. 
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Move Characters and Edit Operation, The 

MCE operation, often referred to as the 
"editing" operation, is provided so that 
amount fields can be punctuated for read- 
ability. Dollar signs, decimals, and commas 
which are not punched in the card may be 
produced by this instruction. In addition, 
insignificant leading zeros can be suppressed 
and special characters inserted. 

In an MCE operation word marks are re- 
quired in the leftmost position of both 
fields (A and B) . When the instruction is 
executed, the B-field word mark is removed, 
the data from the A field is inserted into the 
character positions occupied by blanks or 
zeros in the B field, and the high-order zeros 
in the data are replaced with blanks. 

To demonstrate the use o£ the control 
word with an edit instruction, let us assume 
that the B field contains 

^,t)t)0.'bt) (control word) 

and that the A field contains: 

00003 

After the MCE instruction is executed, the 
field will contain: 

t)t)^t)t).03 

Blanks in the control word are replaced 
with characters located in corresponding 
positions of the A field. The zero in the con- 
trol word is used for zero suppression and is 
replaced by a corresponding character from 
the A field. The rightmost zero in the con- 
trol word is the rightmost limit of zero sup- 
pression. 

The comma in the control word remains 
undisturbed unless zero suppression takes 
place and no significant numerical char- 
acters are to the left of the comma. The 
period is retained in the edited data in the 
same position it occupied in the control 
word. The characters from the word mark to 
the rightmost blank in the example shown 
are considered to be the body of the control 
word. 

If the control word looked like this: 

|b,t)t)0.t)t)CR** 

the characters from the word mark to the 
rightmost blank would be the body of the 
control word and the remaining characters 



would be the status portion of the control 
word. The dollar sign in the body portion is 
left in the same position in the edited data. 

The CR in the status portion remains at 
the completion of editing if the data edited 
was negative. If the data was positive, the 
CR is deleted. If the status portion con- 
tained a minus sign in place of the CR, the 
minus sign would be treated in the same way. 
Asterisks are usually used to indicate a class 
of totals and they remain after editing. 

A few examples of MCE operations follow. 



o 



A Field 


B Field 


B Field 




(before) 


(after) 


00123 


^,t.t)0.-bt) 


t.t.t.1.23 


000123 


•b.t.'bo.-ftt) 


•b1il5l.23 


12345 


•b,t.-bo.t>t> 


•bl23.45 


123456 


^,t)t)0.t»t) 


1,234,56 


12345 


fb.tmo.ti'b 


$bt)123.45 


123456 


fb.D'bo.U'b 


$1,234.56 


Q0123( negative) 


'b,t)t)0.t)t)- 


t)t.'b'bi.23- 


00123 


i.-b'bo.'b-b- 


15t)t)t»1.23t) 


00123 (negative) 


i,t)'b0.t.t)CR 


t)mt>1.23CR 


00123 


£,-bt)0.UbCR 


Wit.1il.23bt) 


00123 


^,fct)0.t)t)** 


1it)t)t>1.23** 



Note that the dollar sign and asterisks are 
left undisturbed in their positions in the B 
field. However, the CR or — (minus) sign is 
deleted when the field is positive. 



Lines 23-24 move the control word to the "amount 
paid" print area; amount paid is then moved and 
edited in the same area. This editing operation is sim- 
ilar to the one performed by lines 21-22. 

Line 25 resets to zeros the field labeled accum before 
adding the "discount allowed" to that field. 

Line 01 (page 02) adds the "amount paid" to the 
ACCUM field. 

Lines 02-03 set up the control word and move and 
edit the "invoice amount" from the accum field to the 
print area. 

Line 04 is a control carriage operation which con- 
ditions the carriage to double space after the next print 
operation. 



Control Carriage Operation (Forms Skip- 
ping), The CC operation is used to control 
carriage spacing and line skipping on a re- 
port form. In this type of statement, only the 
operation code (CC) and a d-modifier are re- 
quired (no addresses need be specified) . 



c 
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Any of the following six d-modifiers can 
be used to control vertical spacing of the 
form 



d-modifier 

K 
L 

/ 
S 
T 



Number of 
Spaces 



Immediate 



Delayed 



Immediate means that the carriage will be 
spaced at the time the d-modifier is encoun- 
tered in the program; delayed means the 
space will be taken after the next print in- 
struction is encountered. 

It is essential when using either type of 
spacing to remember that normally the 
printer automatically skips one space after 
printing. If an immediate space is used, the 
carriage spaces as many lines as are called 
for by the d-modifier. Thus, if a J is written, 
one space is skipped. After spacing, the line 
is printed and then the form automatically 
skips one space (when the W operation 
code is used to initiate printing) . 

If delayed spacing is called for by a diag- 
onal (/) , S, or T, the total number of spaces 
skipped after printing will be the number 
of spaces prescribed including the one that 
normally occurs. Thus, a control carriage 
(CC) operation with a d-modifier of diag- 
onal (/) has no net effect, since only one 
space is specified and the carriage automat- 
ically skips one space. The d-modifiers S and 
T call for two and three spaces, and have 
the net effect of increasing the skipping by 
one or two additional spaces. 

Whenever a control carriage operation is 
used for forms skipping, a control tape must 
be prepared for that particular form. The 
control tape has twelve columns of positions 
(channels) indicated by lines (see Figure 
16) . Holes are punched in each channel 
throughout the length of the tape, which is 
ordinarily the same length as one form of a 
continuous form. These holes indicate the 
end of the form or places in the form where 
skipping is to start or stop. 



gl; ;je 



£.-- 



■Hh- 



Accounts Receivable 
Register 



First Printing Line - Channel 1 



Last Printing Line - Channel 12 



^f4^ 



Accounts Receivable 
Register 



First Printing Line - Channel 1 




Figure 16. Continuous Form and Control Tape 
for Detail Printing 



The d-modifier is used in the CC state- 
ment to control vertical skipping of the 
form; i.e., to specify which channel of the 
tape is to stop skipping. 





Immediate 




After Printing 


d 


Skip to 
Channel I 


d 
A 


Skip to 


I 


Channel 1 


2 


Channel 2 


B 


Channel 2 


3 


Channel 3 


C 


Channel 3 


4 


Channel 4 


D 


Channel 4 


5 


Channel 5 


E 


Channel 5 


6 


Channel 6 


F 


Channel 6 


7 


Channel 7 


G 


Channel 7 


8 


Channel 8 


H 


Channel 8 


9 


Channel 9 


I 


Channel 9 





Channel 10 


? 


Channel 10 


# 


Channel 11 




Channel 11 


@ 


Channel 12 


n 


Channel 12 
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The punched tape is looped into a con- 
tinuous band and mounted on the tape read- 
ing mechanism, as shown in Figure 17. A 
pin feed associated with this mechanism ad- 
vances the tape through the carriage in syn- 
chronism with the printed form. The effect 
is exactly the same as if the control holes 
(channel punches) were punched along the 
edge of each form. 



6 


Label 


1$ 


Operation 

16 20 21 


25 


30 


35 


1 , , . 


C.C. . 


A. 










O I 



causes a skip to channel 1 to be initiated 
after the next line is printed. 



Line 05 prints the assembled print data starting with 
position 401, which was assigned by the processor as a 
result of the Origin statement that appears in the 
beginning of our program. 




Figure 17. Tape Reading Mechanism of the Tape- 
Controlled Carriage 



If the statement given is 



Operatron 



an immediate skip to channel 1 of the con- 
trol tape is initiated, however, the statement 



Write a Line Operation, The code for a 
Write a Line operation is W. The operand 
specifies the leftmost position of the print 
area, which must have an address ending in 
01, The addressed core storage position is 
printed in print position 1; subsequent 
higher-numbered core storage positions are 
printed in print position 2; etc. The posi- 
tion immediately to the left of the group 
mark with a word mark is the highest-num- 
bered storage position that is printed. After 
a line is printed, the carriage automatically 
skips a space. The WS operation code (Write 
a Line and Suppress Spacing) can be used 
in place of the W operation code if it is de- 
sired to suppress the automatic spacing after 
printing. 



Line 06 is a BCV operation which is used to sense 
the end of a form and to branch to the instruction that 
initiates a forms skip. 



Branch on Carriage Channel 12 Operation, 

The BCV operation tests the carriage chan- 
nel 12 indicator. This indicator is turned on 
when a hole is sensed in channel 12 of the 
carriage control tape and is turned off when 
any other channel hole is sensed. If the in- 
dicator is on when tested, the program 
branches to the address of the instruction 
specified by the A operand. If it is off, the 
program goes to the next instruction. 



Line 07 causes an unconditional branch to the ad- 
dress of the instruction labeled lstcd. 

Line 08 causes the form to skip to a new page. The 
end of the previous page was sensed by line 06. The 
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continuous form and carriage control tape are shown 
in Figure 16. In this problem we have chosen channel 1 
to represent the first printing line of a page. There- 
fore, a skip to channel 1 is initiated when channel 12 
is sensed. 

Line 09 tests for last card and initiates a branch to 
Halt after the last card is processed. 

Line 10 causes an unconditional branch to the ad- 
dress of the instruction labeled start. 

Line 11, labeled halt^ causes the program to end 
after the last card is processed and the last line has 
been printed. 



The order in which the fields appear on the report 
form is shown in Figure 19. Note that "item amount" 
is printed in the amount column for each detail line, 
"total amount by sub ledger" is printed each time the 
sub ledger account number changes, "total amount by 
general ledger" is printed each time the general ledger 
account number changes, and "total amount by de- 
partment" is printed each time the department number 
changes. Therefore, we have three classes of totals. 

1 . Total by sub ledger 

2. Total by general ledger 

3. Total by department 



PrograiTifTiing Example 2. 

Detail Printing with Three Classes of Totals 

Detail printing with three classes of totals is similar 
in many respects to the detail printing program ex- 
plained previously. For that reason, we will explain 
only those concepts that are different or new. 

Figure 18 shows the fields, indicated by check marks 
((^), that are to be detail-printed on the report form. 



After each total the form advances one extra space. 
Class one, two, and three totals are identified by one, 
two, and three asterisks, respectively. 

Figure 20A, block diagram, and Figure 20B, de- 
cision table, describe this program in general. The pro- 
gram starts with the resetting of the accumulators to 
zeros, the turning off of switch 2, and the reading of a 
card. The accumulators referred to are not true ac- 
cumulators. They are merely areas in core storage 



c 



PAYABLES DISTRIBUTION 



Invoice 
Date 



Day 



22 
33 

a 

5»5 5' 5 
66 
7 7 



Vendor 
Abbreviation 



00000000 

6 7 8 9 10 1112 13 
11111111 

22222222 
33333333 
44444444 
55555555 
66666666 

nmni 

88888888 
99999999 

e 7 8 9 10 11 12 13 



0000 

14 15 16 17 
1111 

2222 
3333 
4444 
5555 
6666 
7777 
8888 
9999 

14 15 16 17 



Vendor 
Number 



00000 

18 19 20 21 22 
11111 

22222 
3 3333 
44444 
55555 
66666 
77777 
88888 
99999 

18 19 20 21 22 



Our 
Invoice 
Number 



00000 

23 24 25 26 27 
11111 

22222 
33333 
44/44 
5 515 5 5 
66666 
77 77 7 
88888 



99999 

23 24 25 26 27 



Gen 
Ledg 



Sub 
Ledg 



Account 
Number 



000 

30 31 32 
1 1 1 

222 
333 
4/4 

5I55 
666 
777 



999 

30 31 32 



000 

33 34 35 
1 1 1 

222 
333 
4/4 

5155 
666 
777 
888 

999 

333435 



000 

36 37 38 
1 1 1 

222 
333 
4/4 

5155 
666 
777 
888 
999 

36 37 38 



Part 
Number 



00000 

39 40 4t 42 43 
11111 

22222 
33333 
44444 
55555 
66666 
77777 
88888 
99999 

39 40 41 42 43 



Order 
Number 



000000 

44 45 46 47 48 49 
111111 

2 2 2 2 2 2 
333333 
444444 
555555 
666666 
777777 
888888 
999999 

44 45 46 47 48 49 






000 

50 51 52 
1 1 1 

222 
333 
444 
555 
666 
777 
888 
999 

50 51 52 



Due 
Dote 



Mo 



Day 



Quantity 



00000 

57 58 59 60 61 
11111 

22222 
33333 
44444 
55555 
66666 
77777 
88888 
99999 

57 58 59 60 61 



Item 
Amount 



OOQOOiOQ 

64 65 66 67 68 '69 70 

1 1 1 1 1 ll 1 

I 

22222I22 

I 

33333I33 
444/4I44 

5 5 515 5|5 5 

6 6 66 6i'6 6 

I 

77 777|77 

I 
8 8 8 8 8|8 8 

I 
99 9 9 9|9 9 

64 65 66 67 68 69 70 



0000000000 

71 72 73 74 75 76 77 78 79 80 
1111111111 

2 2 22222222 
3333333333 
4444444444 
5 5555555 55 
6666666666 
7777777777 
8888888888 
9999999999 

71 72 73 74 75 76 77 78 79 80 



Figure 18. Card Format for Detail Printing with Three Classes of Totals 
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EXPENSE DISTRIBUTION 








By Department or Branch 






Dept 


Account No 


Our 
Invoice 
Number 


Date 


Amount 






Gen 
Ledg 


Sub 
Ledg 


/Vte 


Day 






82 
82 


431 
431 


112 
112 


12066 
12153 


12 
12 


10 
28 


300.00 
300.00 
600.00* 






82 
82 
82 
82 
82 
82 


431 
431 
431 
431 
431 
431 


113 
113 
113 
113 
113 
113 


12066 
12066 
12066 
12153 
12153 
12153 


12 
12 
12 
12 
12 
12 


10 
10 
10 

28 
28 
28 


150.00 
150.00 
125.00 
150.00 
150.00 
125.00 
850.00* 






82 
82 
82 
82 
82 
82 


431 
431 
431 
431 
431 
431 


114 
114 
114 
114 
114 
114 


12066 
12066 
12066 
12153 
12153 
12153 


12 
12 
12 
12 
12 
12 


10 
10 
10 

28 
28 
28 


50.00 
75.00 
50.00 
50.00 
50.00 
75.00 
350.00* 






82 


431 


520 


12149 


12 


28 


360.43 
360.43* 






82 


431 


700 


12082 


12 


14 


2.25 
2.25* 






82 


431 


750 


12003 


12 


01 


100.00 
100.00* 






82 


431 


810 


12112 


12 


18 


70.20 
70.20* 






82 


431 


850 


12043 


12 


07 


24.75 
24.75* 

2357.63** 






82 

J 


432 


841 


12151 


12 


28 


1792.86 
1792.86* 

1792.86** 

4150.49*** 




Print 










Positions 1-3 5-7 


9-11 13-17 


19-2 


22- 


23 25-36 



Figure 19. Form Layout for Detail Printing with 
Three Classes of Totals 



designated for accumulating totals. The steps per- 
formed thus far by the program may be termed initial- 
izing steps, so called because they are performed only 
once during the program and are used to get the pro- 
gram started. 

As indicated in the next square in the block diagram, 
the control fields (department number, general ledger 
number, and sub ledger number) are read from the 
first card of the deck and from each card that follows 
a total and are stored in a work area. These numbers 
in the work area will be used by the program to recog- 
nize changes in control field numbers. Switches 1 and 2 
will be used to remember the classes of totals taken. 
After a total is taken, the particular switch will be 
reset to its off status. 



The next step is to assemble a detail line and print 
data. The next step is to test for last card. If the final 
card has been processed, three classes of totals will be 
required. Before the totals are taken, Switch 3 is turned 
on to remember the last card condition. After the 
totals are taken, Switch 3 is tested to end the program. 
The item amount will be added into each of the three 
accumulators. After the test for last card, another card 
is read. When this is done, the three control fields in 
the card and the three control fields in work storage 
are compared one at a time. If the fields are found to 
be equal, no totals are required and the program can 
loop back to assemble and print another detail line. 
If any control field is found to be unequal, a total or 
totals will be required. To properly set the switches, it 
is important to start comparing the control fields with 
the most significant control field (department num- 
ber) and to end with the least significant control field 
(sub ledger number) . The first unequal comparison 
does not turn on a switch, whereas the second and 
third unequal comparisons turn switches 2 and 1 on, 
in that order. 

Before a class one total can be printed, the print 
area must be cleared to blanks. This is required because 
the area from which the detail line is printed is the 
same area from which the total lines are printed. If 
this area is not cleared, portions of the detail line data 
will be printed erroneously along with the totals. 

The class one total is assembled in the print area, is 
printed, and its associated accumulator is reset to 
zeros. If switch 1 is found to be on, this means that only 
a class one total is required, and the program will go 
back to the process of assembling another detail line. 
If switch 1 is off, a class two total is assembled, printed, 
and its associated accumulator reset to zeros. Switch 2 
will be tested. If it is found to be on, which means that 
class one and class two totals are required, the program 
returns to assemble another detail line. If switch 2 is 
found to be off, a class three total is printed and its 
associated accumulator reset to zeros. The program 
will return to assemble the next detail line, unless 
switch 3 is on. 

In our example you will find that a switch is merely 
a position of core storage designated SW; when a word 
mark is placed in that position, the switch is on. When 
the word mark is removed, it has the effect of turning 
it off. 

The four program coding sheets for detail printing 
with three classes of total are shown in Figure 21. These 
are used to define storage areas, work areas, constants, 
and the program instructions. 

Line 01 starts the assignment of storage with position 
401. 
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Reset 

Accumulators 
to Zeros and 
Turn Off Switch 3 



Read 
Card 



Store 
Control 
Fields, Turn 
Off Switches 
1 and 2 



Assemble 
Detail 
Print Line 
and Add 
Item Amount 
to Accumulators 




Turn On 
Switch 3 
(To Remember 
LC Condition) 



/■ 












/ 


Turn On 
Switch 2 
Class 2 Total) 










/- 


Turn On 
Switch 1 
(Class 1 Total) 







Clear Print 

Area, 

Assemble 

Class One 

Total, and 

Reset Accumulator 

One to Zeros 



Yes 




Assemble 
Class Two 
Total, end 
Reset Accumulator 
Two to Zeros 



Print 

artd 

Space 




Assemble 
Class Three 
Total, and 
Reset Accumulator 
Three to Zeros 



ro 




(Last Card 
Processed?) 

Figure 20A. Block Diagram for Detail Printing with Three Classes of Totals 



Programming the Card System 37 



** TEST CONTROL CHANGE 












- 










1 1 DEPT. Na READ IN VS DEPT. NO. 


















1 PREVIOUS CARD 


^ 


= 


= 














- 


2 1 GEN LEDG NO. READ IN VS GEN LEDG 




















1 NO. PREVIOUS CARD 


• 


^1= 
















3 1 SUB LEDG NO. READ IN VS SUB LEDG 




1 
















1 NO. PREVIOUS CARD 




• ^ 
















■1 

1 




















4 i PRINT DEPT TOTAL 


X 


i 
















5 1 PRINT GEN LEDGER TOTAL 


X 


x! 
















6 i PRINT SUB LEDGER TOTAL 


X 


X 


X 
















1 























Figure 20B. Decision Table for Detail Printing with 
Three Classes of Totals 



Lines 02-09 describe the print area and lines 10-17 
describe the card read area. Line 18 defines an edit con- 
trol word. Lines 19-21 reserve three 3-position work 
fields for the control field numbers. Lines 22-24 set up 
three 8-position accumulators. Line 25 (page 1) and 
lines 01-02 (page 2) reserve three positions of storage 
to designate the three switches to be used by the pro- 
gram. 

Lines 03-05 are Subtract (S) operations which reset 
the three accumulators by subtracting each from itself. 
The result is the same as if we had performed the fol- 
lowing arithmetic: 

123 
-123 

000 



Subtract Operation, In a subtract operation, 
the data addressed by the A operand is sub- 
tracted from the data addressed by the B 
operand, digit by digit, starting in the right- 
most position. The result that is developed 
replaces the data previously stored at the B 
address. 

The subtract operation is terminated by 
the word mark in the leftmost position of 
the B field. If the A field is smaller than the 
B field, both fields require a word mark. 



Line 06, a CW statement, turns off switch 3 by re- 
moving the word mark. 



Clear Word Mark Operation, The CW 

statement clears the word mark at the ad- 
dress specified by the A operand or the word 
marks specified by the A and B operands 
without disturbing the data. 



Line 07 reads a card. Lines 08-10 are MLC statements 
which move the three control fields to working storage. 

Lines 11-12 turn off switches 1 and 2 by removing 
word marks. The CW statements on lines 11 and 12 
could have been combined and written as a single 
statement, thus: 



() 



6 


Label 


15 


°p'™«?^ 


21 26 


30 


5? 


1 
i . , . 


c.w . 


SWl, . S.W.2 


1 








In this case, the word marks at both addresses (SWl 
and SW2) would be cleared by a single statement. In 
effect, removing these word marks is equivalent to turn- 
ing off these switches. 



Lines 13, 14, and 15 are MCS statements which move 
the three control fields — department number, general 
ledger number, and sub ledger number — to the print 
area and eliminate the high-order zeros from each field. 



Move Characters and Suppress Zeros. The 

MCS statement is similar to the MLC state- 
ment in certain respects, i.e., it is designed 
to move data. However, zeros to the left of 
the leftmost significant digit of the data are 
eliminated and replaced by blanks. Removal 
of nonsignificant zeros is considered an edit- 
ing function. The word mark in the leftmost 
position of the A field defines the size of the 
field; B field word marks are erased. 



Lines 16-18 are MLC statements which move the 
invoice number, month, and day to the print area. 
Line 19 moves the edit control word to the amount 
field (print area) . Any asterisks in the amount field 
from a previous total will be eliminated by the move. 
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Page No 


.lO.ll 

1 2 


of 


J 


34 


— 


Line 
3 5 


Label 

6 15 


Operation 

16 20 


OPERAND 

21 25 30 35 40 45 50 56 60 65 70 


0, 1 , 




ORG 


4,0,1 S.T,ART. .STO,R,A.GE, , AS.S.I GNME N T AT POS.. 100. 


2 


PRT.T N.eI 






P. A 




l,x3.6,,.G 






,D.E,FI ,N,E. P,R,I,N.T, ,LIN.E, 






















0,3 


DERTL. 1 














3 






, . . ,F 


IE.LDS .: .D.E.PA11,TJVIE,N,T, .N,0, 
























0,4 


GEN,L . 1 














7 












, . . , , ,G.E.N,EJlAiL, ,L,E,D.G.E,R 




Np, , 




















0,5. 


S,URL . 1 














1, 1 , , . 














. . .S.U,-R, ,LE.D,G,E,R. .N,0, 


























0,6, 


INYNQLi 














1, 7. . . . 














, , ,i,N,yo,i,c.E, ,N,o, , 


























0.7, 


MOL , . 1 














2, Q , , . 










1 1 . 




, , .MONTH 


























o,e. 


DAY.L . 1 














2,3 .. . 










■ 1 , 


> 1 


. . .DAY 


























0,9, 


AMNTL 1 














3,6 , . . 










1 1 1 




, ,• .AMaiJ,N,T 


























',0, 


rdare.aI 








n,A, 






1 , X 7, Q ,. G 


r 








n.E,F.T 


N.E .CAR.n ,R,EAD.I,N.G ,A.RE,A 


























1,1, 


MOG , . 1 














1, .. 2. , . 










. . .F 


I,ELD,S,:, , ,MO,N.T.E 


























'>2. 


nAY,C, . 1 














3, ,.4, . . 














,D,A,Y 


























',3. 


T,N VNod 














2,3. ,,2.7. 














,r ,N,VO.I,GE. ,NO , 


























i^^i 


GEN.C, . 1 














3,0., .3, 2. 












1 1 . J 1 , 


,G,KHERAL, .LEDGER 


N,0 




















'.5, 


S,U,BjC, . 1 














3,3. ..3,5. 














,S,U,R .LE,DG,E.R .NO . 






















>.6, 


DEP.TC. 1 














3,6., ,3,8. 














,D,E.PAJl,TM,E,N.T ,NO, . 






















' ,7. 


AMNTG 1 














6,4. ..7,0. 














,A,MOUJSr,T 






















1,8, 


QTRMV^M 








DCW 




@,l5.l5.ti.tib 







t5,t5.l5,t),l5 


§ 




,E.D,I,T, ,C 


0,N,T,R.O.L, ,WQI\E) , 


























1,9, 


DEP.TW i 








DC W 




#,3. . , . 












.DE.EI ,N,E 


,WO,RK AREAS , , 


























2<0, 


ge;n,w . 1 








D,GW 




#,3. , , . 










1 1 1 


1 ■ 1 1 1 t 


I 1 1 , 1 1 1 I 1 1 , 1 


























2. 1, 


S,U,B,W, , 1 








DGW 




#,3, . , . 
















1 1 i 1 1 J 1 


























2,2. 


ACCUMli 








T)QW 




#,8, , , . 












P^f,I,N.E 


,AC,c,u 


MUIvATOR,S 


























2,3, 


AGC,UM2; 








QGW 




#,8, , . . 












1 1 1 , I 1 




























2,4, 


AGCTIMsi 






new 




#.8, , , . 










1 , I 


. 1 1 1 1 1 




1 1 1 I 1 I 1 






















2 5, 


s.wi, :.;,:, 


nc 




#,L , , . 


^J 


L^ 


D.E,F,I,N,E 


StWIiTiQff,E|S, , , 1 




— 1 


.-J 


^ 




.^ 































Page No.|0|2| of 04 
1 2 


— 


Line 
3 5 


Label 

6 «5 


Operation 

16 20 


OPERAND 

21 25 30 35 40 45 50 55 SO 65 70 


2 


S.W2, , . 1 . , , 


D,C. , , 


#.1 




s,\y3, , 






D,C 




#1 
















0,3 


ST, ART 






s, 




AC,G.U,M1,.,AC.C.UML 












RE.S.E.T. .AGG,U.M.U,LA,T.O.R.S. ,TO. ,7.,ER.O.S i 


0,4 








s, 




A,C.G.U.M2,. AG CIT M2 
















0^5, 
0,6, 








.s. 




A,G.r.TTM..q, .A/-GIT,M3. 






















c,w 




SW.3 , , , 












T,UJl,N, .S.W,I,T,G,H. ,3 OF.F (LG. CONDITION) 




0,7. 








R 




L.RDAJIEA 














RE.AD. ,A iGARQ ,.,,.,....,,,..,.,,. 




0,8, 


3 TO. RE 






MLG , 


DE.P.T.C., DEP.TW . 














S.TOR.E. .CON,TRO.L, , F.I. ELDS 




0,9, 








MLC . 


GE.NG,,.GENW. . . . 


















'.0. 








MLG , 


=^U,RG.,.SUR .W . . . 


















1,1, 








GW . 


3W,1 






1 1 








TUR.N, SWI.TGH£S, ,0,N.E. A.ND. ,T,W,0 .O.F.F. , . 




1,2, 








cw , . 


SW.2 . , , 




^ 






1 1 


^ 






1 ,3, 


ASSEM 






MCS. , 


DE.P.TC., DEPTL. , 














ASS.E.MRLE DE.TA.I ,L. .P.RI ,N,T. ,L,I ,N,E. 




1,4. 








MCS, , 


GENC.CENL. . . . 


















1,5, 








MCS. . 


5UBC..5 .U,B.L. . . , 


















1 ,6, 








MLG , 


IN,VNOiC,.,I.N.V.N.O.L 


















•.7. 








MLC , 


M,O.G.MO,L 


















1 ,e, 








MLG i 


DAyC.,JVI.O,G 


















1 ,9. 








ML,C,W,A 


C,TR.L,WD, ,A,MNTL 


















2,0, 








MCE , 


AMN,TG.,A,MN.T.L-.3 


















2. t , 








A, , , , 


AMN,T.G.,,A,G,C.UM1, 














AD.D. IT.KM AM.O,U,N,T, .T.O, AC.CU,MU.L.A.T.0^3 . 




2 3, 




1 




A . . . 
















1 f , J 1 1 , 1 1 J 1 1 I , i 1 J 1 1 1 1 1 1 1 , 1 1 1 1 i 1 










A, , , , 


AMN,T,C., ,A,CG.U.M3 


















2,5, 








w , , , 


PRL1,N.E , , . . , 














P.R,I.N.T, £)ETA,IL, ,L,IN£, ..,,,.. 




. , . , 






^i^c, , 


S,E,T,S.W.3, , 




i-j 


L. 






^__ 


T,E,S,T, ,F,0,^ ,LA.S.T, .CA^R.D, | 



Figure 21 . Coding Sheets for Detail Printing with Three Classes of Totals 
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Page 


Nc 


).iMi of 

1 2 


04 


Line 

3 5 


Label 
6 i: 


Operation 

16 20 


OPERAND 

21 25 30 35 40 45 50 55 60 A.^ 


PL 

2 


1 
, 1 . , 1 1 1 




R, - . . 


1,,PPAPPA, , . 






, , . ,R.E.A,D, A. CARD. ,,,,., 1 







c, , 


i 


DEPTCi, PEPT 


W, 




.COMPARE, DEPARTM,EJ^,T: N,0. , , 






0,3 




B,^ , 




XQXAh , , , . 












0,4 








c, , , 




GEN.C, .GEN.W, 






, , , ,GO,MRARE, ,GENE.RA,L, .L.EP,GER, N,C 


>,.,,, 






0.5, 








^^ 




S E.T.S.W2. , , . 














0,6, 








c , 




S.URC.S 


II BW. 






, , , .G,0,MPAR,^, ,SUB. .L,E,D.G£,R, ,N,0. . . , 








0,7. 








b,e; 




ASS ,KM 








I > • > • I ' ' 1 • 1 1 t 1 • ' > I ^ 1 1 








0,6, 








S W 




s,wi. . . 








, . . .T.U,R,N, S.WI.TGH, ,0,N,E. .O.N 








0,9. 








B, , 




T.QT.AL 




i 1 












'.0 


S.E.TSW2 






S.W 




S.W,2. . . 








, , , .TITRN. S.W.T.T.G.R ,TW,0. O.N 








1,1, 


T,0,T,A.L 






c,s, 




A.MNT1. 








, , , CLEAR. PR.I.N.T. AREA 








',2, 








MLGW^ 


r,T,R,T.Wri, .A.MKTT. , . . 
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Figure 21 . Coding Sheets for Detail Printing with Three Classes of Totals ( contd.) 



Line 20 moves the amount to the print area. The B 
operand is address-adjusted so that the position im- 
mediately to the left of the printing positions which 
print the asterisks can be addressed. In our example, 
if the position addressed by amntl^ which is the loca- 
tion of the rightmost asterisk, had been assigned ad- 
dress 688 by the processor, then amntl minus 3 would 
be 685, the position to the left of the asterisks. 



Address Adjustment of an Operand. Address adjust- 
ment is used by the programmer to tell the processor 
to arithmetically adjust the address of an operand. The 
programmer indicates address adjustment should be 
performed by writing a plus (+) or minus (— ) sign 
after the symbol. The processor then assigns an address 
that is a given number of positions away from the spe- 
cific address, the specific address being the address as- 
sociated with the label. 



o< 



40 



© 



o 



If the storage position lOOQ has been assigned to the 
symbol alpha and the programmer writes two operands 
ALPHA + 40 
ALPHA — 30 

the processor then assigns to these operands the ad- 
dresses 

1040 
970. 

Lines 21-23 add the item amount to each of the three 
accumulators. Line 24, a Write a Line operation (W) , 
prints a detail line from the detail data in the print 
area. Line 25 tests for last card. Line 01 (page 3) reads 
a card into the read area. 

Line 02, a Compare operation (C) , causes the con- 
tents of the A and B fields (department numbers) to 
be compared. 



Compare Operation. In a Compare state- 
ment, the rightmost position of the A and B 
fields is addressed by the A and B operands, 
respectively. The data in the fields, starting 
with the rightmost position, is compared 
until a word mark is encountered in either 
field. If the B field is longer than the A field, 
in which case a word mark will be encount- 
ered in the A field first, an unequal compare 
results. If the data in the A and B fields is 
the same, the equal indicator is turned on. 
If they are not the same, either the high or 
low indicator is turned on as well as the un- 
equal indicator. 

When the value of the B field data is less 
than the value of the A field data (B < A) , 
the low indicator turns on. When the value 
of the B field data is greater than the value 
of the A field data (B > A) , the high indi- 
cator turns on. 

Comparing is not restricted to numerical 
fields. Alphabetic and alphameric fields can 
also be compared. The fields compared must 
have the same bit configuration to be equal. 
For this reason, comparison of a plus zero 
and a minus zero results in the unequal 
indicator being turned on. 

To determine high or low comparisons, 
the programmer should remember that the 
character rank (collating sequence) from 
lowest to highest is 

1. blank 

2. special characters 

3. letters (A-Z) 

4. numbers (0-9) 



The following comparisons of A and B 
fields show the indicators that are set as a 
result. 

Indicators 
A Field B Field Unequal High Low 



01 


02 
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X 




02 


01 


X 
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X 




IJ 


IK 
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X 
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X 




X 


IK 


IJ 


X 




X 


ACA 


ABA 


X 




X 


123 


124 


X 


X 





Line 03, a BU operation, tests the Branch Unequal 
indicator. If the department numbers are unequal, 
the program will branch to the instruction labeled 

TOTAL. 



Branch on Unequal Compare Operation. 

If the Branch Unequal indicator is on when 
tested by this instruction, the program 
branches to the address specified by the op- 
erand. 



Lines 04-05 function similarly to the previous two 
lines. In this case, however, the fields compared con- 
tain general ledger numbers and the branch is to the 
instructions labeled SETSW2. 

Line 06 compares the sub ledger numbers, and line 
07, a BE operation, causes the program to branch to 
the instruction labeled assem, if the sub ledger numbers 
are equal. 



Branch on Equal Compare Operation, If 

the Branch Equal indicator is on when 
tested by this instruction, the program 
branches to the address specified by the 
operand. 



Line 08 turns switch 1 on by setting a word mark 
in a position of storage. The effect of line 08 is to set 
a switch that can be tested by another program step 
at a later time. 



Set Word Mark Operation. This operation 
causes a word mark to be set in the position 
of core storage designated by the A operand. 
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The character is unchanged in a position 
where a word mark is set. Two word marks 
can be set by a single SW operation, provided 
both the A operand and B operand contain 
an address. The following statement will 
cause word marks to be set in storage posi- 
tions 501 and 532. 



carriage so that it skips two spaces after the next print 
instruction. Line 17 causes the class one total to be 
printed. Line 18, a BW operation, tests switch 1 which 
is represented by a word mark and branches to the 
instruction labeled store if the word mark is present. 
In effect, this is the instruction that tests switch 1. 



i) 
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6 15 


Operation 

16 20 
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1 
1 . ; , 


S,W 


5.0,1,, ,5.3, 2 









Line 09 causes an unconditional branch to the in- 
struction labeled total (start of total routine) . Line 
10 turns switch 2 on by setting a word mark at the 
address symbolized by SW2. Line 11, a CS operation, 
clears the print area of all data and resets the area to 
blanks. 



Clear Storage Operation, The CS operation 
causes storage to be set to blanks and word 
marks to be removed, starting at the address 
specified by the operand and continuing 
through lower-numbered positions until an 
XXOO address is encountered, i.e., an address 
that ends in zero-zero. The following state- 
ment 
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results in clearing storage positions 482 
through 400, whereas the statement 



Label 
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Operotion 
16 20 
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, . . , . 1 , , . 


CS, . , 


4 0,0 


1 







would clear storage position 400 only. As 
many as 100 positions can be cleared by a 
single CS statement. 



Branch on Word Mark Operation, The BW 

operation tests the position specified by the 
B operand for a work mark and, if the word 
mark is present, branches to the address of 
the instruction specified by the A operand. 



Lines 19-25 are similar to lines 12-18. They assemble 
and print a class-two-total line identified by two 
asterisks. 

Lines 01-06 (page 4) assemble and print a class three 
total identified by three asterisks. 

Line 07 tests switch 3 for a word mark. If the word 
mark is present (meaning that the last card has been 
processed) , the program branches to the instruction 
labeled halt. 

Line 08, a B operation, is used to initiate an uncon- 
ditional branch to the instruction labeled store. 

Lines 09-10 turns on switch 3 to remember the last 
card condition and branches to the start of the total 
routine which is labeled total. 

Line 11 ends the program after the last card has 
been processed. 

Programming Example 3. 
Reading/Puriching and Multiplication by 
Repetitive Addition 

This programming example introduces two new opera- 
tions. In this example an amount field is read from each 
card. The discount is calculated, by repetitive addition, 
at a certain discount rate (.07) and the discount is 
punched. The card format is as follows: 



Card columns 



1-4 discount (XX.XX) 
5-9 amount (XXX.XX) 



Line 12 moves the edit control word to the amount 
field in the print area. Line 13 moves a single asterisk 
to the print area to identify the total as a class one total. 
Since the A operand is a literal (@*t)t>@), it is pre- 
ceded and followed by an at (@) sign. Line 14 moves 
the class one total to the print area and edits it. Line 15 
resets accumulator 1 to zeros. Line 16 conditions the 



When multiplication is performed using program- 
med repetitive addition, the problem 



123.45 
X .03 

3.7035 



42 



c 



o 



is accomplished by adding the number 123.45 to a 
specific area of storage three times, thus 



00000 
+ 12345 

12345 
+ 12345 

24690 

+ 12345 



3.7035 (result) 



Likewise, the multiplication: 



123 
X.23 



28.29 



is done by adding the number 123 to an area three 
times. The multiplicand is then shifted left one posi- 
tion, and added two more times. 

0000 
+ 123 



0123 
+ 123 



0246 
+ 123 



0369 
+ 123 

1599 

+ 123 

2829 (result) 



Programmed division is performed in a similar man- 
ner, except that repetitive subtraction is used in place 
of repetitive addition. 

Figure 22A, block diagram, and Figure 22B, decision 
table, describe this program. In them the first functions 
shown are reading a card and testing for last card. The 
next is the setting of the repetitive-addition count to 7 
and the resetting of the accumulator to zeros. The 
accumulator is an area of storage used to accumulate 
discount amount. 

The discount amount is calculated by adding the 
amount to the accumulator the number of times desig- 
nated by the count (in this case, 7) . Each time the 



Read Card 



Set Count 
to 7 



Reset 

Accumulator 
to Zeros 



Add Amount 

to 

Accumulator 



Subtract 
Constant 1 
from Count 




?unch 

Discount Amount 

ond Rate 



No 




Last 
Card 



Yes 



Halt 



Figure 22A. Block Diagram for Reading/Punching and 
Multiplication by Repetitive Addition 
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2 1 SET ITERATION COUNT = 7 
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3 1 SET ACCUMULATOR = ZERO 
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4 1 GO TO ITERATION 
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5 j GO TO STOP 
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** ITERATION 






















1 1 SET ACCUMULATOR + AMOUNT 


X 




















2 I SET ITERATION COUNT - 1 


X 
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**l TEOT ITERATION COUNT 






















1 1 ITERATION COUNT = ZERO ? 
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Y 


















2 1 GO TO ITERATION 


X 




















3 ; MOVE ACCUMULATOR TO DISCOUNT 




X 


















4 j PUNCH DISCOUNT 




X 




- 


- 












5 1 GO TO START 




Xj 










1 





















Figure 22B. Decision Table for Reading/Punching and 
Multiplication by Repetitive Addition 
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amount is added, the count is reduced by one. When 
the count reaches zero, the discount amount is moved 
from the accumulator to the punch area and the card 
is punched. Then, the next card is read and the pro- 
gram is repeated. 

Figure 23, the coding sheet for this example, contains 
the 18 statements required to tode this program. Lines 
01-04 define the card reading and punching areas of 
storage. Lines 05-06 reserve positions in storage, and 
lines 07-18 constitute the program itself. 

Lines 01-02 define the read area. Lines 03-04 define 
the punch area. Line 05 reserves one position of storage 
labeled count^ and line 06 reserves six positions of 
storage labeled accum. Line 07 reads a card. 

Line 08 moves the literal "7" to the position symbol- 
ized by COUNT. The plus sign in front of the 7 designates 
it is a positive numerical literal. 



Move Numerical Portion of Single Char- 
acter. The MLNS operation moves the nu- 
merical bits (8421 bits) from the position of 
storage addressed by the A operand to the 
position of storage addressed by the B oper- 
and. No word marks are needed in either 
position because only a single digit is trans- 
mitted. The A field character is unchanged 
by this operation. Also, the zone bits (AB 
bits) of the B field character remain un- 
changed. 



Line 09 resets the accumulator to zeros. Line 10 adds 
the amount to the accumulator. Line 11 subtracts a 
literal "one" from the count. 

Line 12, a BCE operation, tests the position symbol- 
ized by COUNT to determine if the count has reached 
zero. If it has, the program branches to the instruction 
labeled pch. If not, it proceeds to the next instruction. 

Branch If Characters Equal Operation, The 

BCE operation is used to test a specific posi- 
tion of storage for a particular character and 
to branch if that character is present. If that 
character is not present, the program pro- 
ceeds to execute the next instruction. 

The position to be tested is indicated by 
the B operand and the particular character 
is the d-modifier. The address to which the 
program branches is indicated by the A oper- 
and. Note that the d-modifier character and 
the character to which it is compared must 
have the same combination of bits to be 
alike. 

Line 13 branches unconditionally to the instruction 
labeled mult. Line 14 moves the product, the "dis- 
count amount," to the punch area. Note that the two 
rightmost digits of the product are dropped because of 
the A operand being address-adjusted. Line 13 punches 
a card. Line 16 tests for last card. Line 17 branches 
unconditionally to the instruction labeled start. Line 
18 ends the program after the BLC operation (line 
16) senses the last card. 
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Figure 23. Coding Sheet for Reading/Punching and Multiplication by Repetitive Addition 
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Programming Example 4. 

Multiple-Field Crossfooting with Control Register 

This payroll application has as its objectives to: 

1. Crossfoot each current earnings card and to punch 
the resulting gross earnings. 

2. Accumulate a total of gross earnings by depart- 
ment and to print that total. 

3. Sequence-check the card deck by department num- 
ber and to stop processing if a sequence error is 
detected. 

The card format of the current earnings card is as 
follows: 

Card columns 14-16 department number (XXX) 
35-39 gross earnings (XXX.XX) 
40-43 miscellaneous earnings 

(XX.XX) 
44-48 regular earnings (XXX.XX) 
49-52 extra shift earnings 

(XX.XX) 
53-56 overtime premium earnings 

(XX.XX) 

Miscellaneous, regular, extra shift, and overtime earn- 
ings are added together (crossfooted) to obtain gross 
earnings. 

This application combines card reading, card punch- 
ing, and printing functions in one program. No new 
operations are described or used. A listing of the opera- 
tions thus far used follows: 



DA 


Define Area 


DC 


Define Constant 


DCW 


Define Constant with Word Mark 


DS 


Define Symbol 


EQU 


Equate 


A 


Add 


S 


Subtract 


ZA 


Zero and Add 


MCE 


Move Characters and Edit 


MCS 


Move Characters and Suppress Zeros 


MLC 


Move Characters to A or B 




Word Mark 


MLCWA 


Move Characters and Word Mark 




from A Field 


MLNS 


Move Numerical Portion of 




Single Character 


B 


Branch Unconditional 


BCV 


Branch on Carriage Channel 12 


BE 


Branch on Equal Compare 


BH 


Branch on High Compare 


BL 


Branch on Low Compare 


BU 


Branch on Unequal Compare 


BLC 


Branch on Last Card 



BW Branch on Word Mark 

BCE Branch If Character Equal 

C Compare 

W Write a Line 

WS Write a Line and Suppress Spacing 

R Read Card to Group Mark with 

Word Mark 

P Punch and Feed 

PS Punch and Stop 

CC Control Carriage 

CS Clear Storage 

CW Clear Word Mark 

H Halt 

SW Set Word Mark 

ORG Origin 

Figure 24 shows the format of the control register. 
The leading zeros in the department number column 
are suppressed. 

Figure 25A, block diagram, and Figure 25B, decision 
table, describe Programming Example 4 in a general 
way. The initializing steps called for in this program 
are to read a card and to turn off the switch. The next 
steps are to store department number in a work area, 
and to reset the accumulator. The earnings are cross- 
footed to gross earnings and the gross earnings amount 
is punched. The gross earnings amount is added to 
the accumulator to accumulate the total department 
earnings. 

The last card indicator is tested. If the indicator is 
on, the switch is turned on, a line is assembled and 
printed, the switch is tested, and the program ends. 
If the last card indicator is off when first tested, the 
next operations performed are to read another card 
and to check department sequence. 

To check sequence, the program compares the de- 
partment number in the read area and the depart- 
ment number in the work storage area. If the numbers 
are equal, signifying there is no change in the control 
number, the program branches back to repeat the 
crossfoot operation. If the result of the compare is high. 



Dept. No. 



3 

5 

1 8 

114 



Dept. Total 



1098.67 
457.83 
785.45 

1945.35 



Printing 
Positions 5-7 



13-20 



Figure 24. Control Register for Multiple-Field Crossfooting 
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Torn Off 
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Store Depart- 
ment Number 
and Reset 
Accumulator 



Crossfoot 
to Gross 
Earnings 



Punch 

Gross Earni ngs 




Figure 25A. Block Diagram for Multiple-Field Crossfooting 
with Control Register 



this condition means there is a change in control num- 
ber (department change) and the cards are in ascend- 
ing order. I£ this is the case, the program proceeds to 
assemble a printing line and to print. After printing, 
the switch is tested. If it is on, the last card has been 
processed and the program is directed to halt. If it is 
off, the program proceeds to test for carriage channel 12. 
A skip is initiated to channel 1 of the carriage tape, 
provided channel 12 was sensed. This is to allow for 
page overflow. If the result of the compare is low, it 
signifies the cards are in descending order, therefore 
out of sequence, and the program is stopped. 

After a line is printed, the program branches back to 
the beginning of the program loop where department 
number is again stored and the accumulator is reset to 
zeros. 
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Figure 25B. Decision Table for Multiple-Field Crossfooting 
with Control Register 



Figure 26 consists of the coding sheets containing 
the forty-three statements used to code this application. 
Line 01 starts the assignment of storage with the ad- 
dress 401. Lines 02-15 define areas and constants, and 
the remaining lines compose the program. 



hine 01 
Lines 02 

-04 
Lines 05 

-10 
Lines 11 

-12 

Line 13 
Line 14 



starts assignment of storage, 
define the printing area. 

define the card reading area, 
define the card punching area. 

reserves a 7-position accumulator labeled 

ACCUM. 

defines an edit control word constant. 
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Line 15 

Line 16 
Line 17 
Line 18 

Line 19 

Line 20 
Line 21 

Lines 22 
-24 

Line 25 

Line 01 
(page 2) 
Line 02 

Line 03 

Line 04 

Line 05 



Line 06 



reserves a 3-position work area for depart- 
ment number storage, 
reserves a 1 -position work area as a switch, 
reads a card. 

turns the switch to its off status by remov- 
ing the word mark at the position labeled 

SWITCH. 

stores the department number in a work 

area. 

resets the accumulator to zeros. 

zero-and-adds miscellaneous earnings to 
the gross earnings field in the punch area, 
add the regular earnings, extra shift earn- 
ings, and the overtime earnings to the 
gross earnings field (punch area) . 
punches the gross earnings amount into 
the card. 

adds gross earnings to the accumulator 
(field symbolized by accum) . 
tests the last card indicator and branches 
to the instruction labeled setsw. 
reads a card. 

compares the department number in the 
work area with the department number 
read from the card. 

branches back to the crossfoot routine 
(labeled crossf) , provided the result of 
the compare operation showed the depart- 
ment numbers to be equal, 
branches to the halt instruction labeled 
SEQERR, provided the department number 
in the read area proved to be lower (of 
lesser value ) than the department number 
in the work area. This condition (A field 
< B field) represents a step down in card 
sequence. 



Line 07 moves the department number from the 
work area to the print area and suppresses 
leading zeros. 

Lines 08 set up the control word in the ^'department 

-09 total" print area, and move and edit this 

amount from the accumulator to that area. 

Line 10 prints a department total line. 

Line 11 tests the position labeled switch for a word 
mark and branches to the halt instruction 
labeled end^ provided the word mark is 
present. 

Line 12 branches to the instruction labeled oflo 
if the channel 12 indicator is on. 

Line 13 branches unconditionally to the instruc- 
tion labeled store. 

Line 14 skips the form immediately to channel 1 
of the carriage control tape. 

Line 15 branches unconditionally to the instruc- 
tion labeled store. 

Lines 16 turn the switch on by setting a word mark 
-17 in the position labeled switch and 
branch to the instruction labeled assem, 
which starts the print routine. 

Line 18 ends the program. 

Line 19 halts the program for a sequence error. 
Note that separate Halt instructions are 
provided for the program-end halt and 
the sequence-error halt although a single 
halt instruction could have been used. 
Separate halt instructions allow the com- 
puter operator to observe which halt in- 
struction is being displayed at the console 
and make it easier for him to find the 
reason for the halt. If only a single halt 
were provided, the reason for the halt 
would not be isolated. 






Section 4. Questions 

1. Which of the following operations is best suited 
to move an edit control word to a field prior to 
editing? 

a. MCE 

b. MGS 

c. MLC 

d. MLCWA 

2. What is the result of editing the two fields shown, 
using edit control word [|b,t)t)0.t)t)— ] ? 

Fields Before Edit Fields After Edit 

000001 (negative) 
643625 (positive) 



The instruction to cause skipping after printing 
a line 

a. must appear before the printing instruction. 

b. must appear after the printing instruction. 

c. can appear before or after the printing instruc- 
tion. 

d. must appear before and after the printing in- 
struction. 

e. none of the above. 

Is it true that a hole in channel 1 of the carriage 
control tape can be used to initiate a carriage 
skip? 
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5. Which of the following statements is not true of 
the print operation? 

a. The position immediately to the left of the 
area to be printed must contain a group mark 
with a word mark. 

b. The addressed core storage position is printed 
in print position 1. 

c. The operand specifies the leftmost position of 
the print area. 

d. A group mark with a word mark must follow 
the highest-numbered core storage position to 
be printed. 

e. The Autocoder operation code for Write a 
Line is W. 

6. Does the carriage skip automatically take place 
when the carriage channel 12 indicator is found 
to be on by the BCV operation? 

7. Using address adjustment, write a statement that 
will move only the 123 portion of the field labeled 
SUM to a 3-position field labeled tot. 

j^234567 SUM is the address of the rightmost 
position 

8. If the contents of the position of storage desig- 
nated SWl is a digit 1 with a word mark and 
the following Branch on Word Mark instruction 
is executed 



« 


Label 


15 


Operation 
16 20 


21 25 30 


35 


I 
] . , , 


BW. , . 


ST.EPX.. ,SW,1 
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which is the location the program advances to? 

a. the next sequential step. 

b. STEPX. 

c. SWl. 

9. Write an instruction that will test the storage 
position labeled code for the letter R, and will 
branch to the instruction labeled start if the R 
is present. 
10, Given the following block diagram, write a pro- 
gram on an Autocoder program sheet that will 
read gross earnings from the cards, accumulate 
a total of gross earnings for all cards, and print 
this total. 
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Add 
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No ^ 


Yes 


Print 
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Halt 





Use these labels in the area definition state- 
ments. 



RDAREA 


- for read area 


GROSS 


- for gross earnings field 


PRAREA 


- for print area 


TOTAL 


- for total field 



Gross earnings amount is to be read from card 
columns 1-5, and the total is to be printed in print 
positions 1-7. 

11. A Compare operation compares two fields and 

a. if they are equal, branches to the instruction 
specified by the A operand. 

b. sets an indicator, which may be tested by subse- 
quent instructions. 

c. if they are unequal, branches to the address of 
the instruction specified by the B operand. 

12. After comparing field A to field B, does the com- 
parison result in an equal or unequal condition? 



Field A 

a. 0000 (unsigned) 

b. 0000 (unsigned) 

c. 0000 (unsigned) 

d. 128J (unsigned) 



Field B 

0000 (positive) 
0000 (unsigned) 
00bt> (unsigned) 
1231 (unsigned) 



13. Write instructions to clear to blanks the following 
storage positions: 

800-999 
600-625 
500-501 
200 only 
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Programming with Disk Storage 
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Section 5 



The sample programs we developed in previous sec- 
tions were based on a system composed of a Card Read- 
Punch, a Processing Unit, and a Printer. In this section 
we will study ways to use the supplemental storage 
provided by the 1311 Disk Storage Drive, and we will 
program some basic disk storage operations in Auto- 
coder language. 

The 1311 Disk Storage Drive supplements the core 
storage area at a reasonable and acceptable cost. Like 
core storage, disk storage can be used to store program 
instructions, tables, and data records. It can also serve 
as a working storage area; i.e., an area for storing inter- 
mediate results, input data, and output data. 

It is advisable in large programs to store the most 
infrequently used subroutines in disk storage, because 
it takes a certain amount of time to read these sub- 
routines into core storage where they can be operated 
on. Using disk storage in this way permits the program 
to execute its functions in the shortest amount of time. 

Some applications require large rate tables. If the 
tables are stored in disk storage rather than core stor- 
age, more core storage is made available for the pro- 
gram and for the input and output areas. 

Data records may be stored in disk storage in either 
a sequential or nonsequential (random) manner. 

Sequential Method 

For sequential storing, virtually unlimited storage is 
available. As soon as one disk pack is filled to capacity, 
it can be removed and replaced by another. 

Data records that are stored sequentially usually 
contain some control field, for example, account num- 
ber, that is in the same sequence as the sequence in 
which the records are stored. This control field makes 
it easy for the computer to scan the sequence of records 
and update or post changes to the records. 
Sequential storing of data is usually used when: 
1. Transactions to be processed are in a given se- 
quence (same order as records) . 



2. Most of the records require processing for any 
given application. 

3. Unlimited storage is needed for the records. 

4. Sequential reports are required by the user. 

The term ''sequential searching" implies that each 
record, starting with the first, must be scanned to 
locate a specific record. However, indexing may be 
used to eliminate the scanning of every record. Index- 
ing is a method of cross-referencing a control field with 
a disk storage address through the use of a table. By 
scanning the table, the computer can obtain the ad- 
dress of the record and thus locate the record without 
sequential searching. 

Nonsequential (Random) Method 

For nonsequential storing, data records have no par- 
ticular sequence so far as control information or con- 
tents is concerned. However, if these data records 
contain a control field that can be used as the actual 
disk address, they can be stored by direct addressing 
and retrieved in the same way. If direct addressing is 
not possible, a form of indirect addressing may be 
used. In indirect addressing, some technique must be 
employed for converting the control field to the disk 
address. A number of such techniques known as ran- 
domizing techniques are available. 

The nonsequential (random) method of data stor- 
age is usually used when: 

1. Sorting of transactions in a given sequence is un- 
desirable, or not possible before processing. 

2. A low percentage of the records is used during 
processing (low activity for many records) . 

3. The maximum number of disk records to be made 
available at one time for processing will fit within 
an established disk storage area. 

4. Nonsequential reports are required by the user. 
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737 7 Disk Storage Operations 

Disk storage instructions consist of five basic opera- 
tions: 

Seek 

Read 

Write 

Write Disk Check 

Scan Disk (special feature) 

The Read, Write, and Scan Disk operations have num- 
erous variations that increase their effectiveness. A 
general description of the various Disk Operations 
follows. 



Seek Operation 

The Seek operation consists of an instruction that di- 
rects the read/write heads to the proper cylinder on 
the disk pack. Data on the disk records is not acted 
upon by this instruction. The seek instruction merely 
positions the access arms at the proper cylinder. 

The Seek instruction is followed by a read instruc- 
tion or a write instruction. The operand of this in- 
struction specifies the core storage address of the Disk 
Control Field (described under read disk operation) . 

Read Disk Operation 

The Read Disk operation transfers data from disk stor- 
age to the core storage area of the processing unit. 

The core storage area where the data is to be placed 
must be defined by an instruction that precedes the 
seek or read instruction. This area is defined thus: 



Disk Control 
Field 
A 



Data 
Field 



tL 



Alternate Core 

Code Sector 

Address 



Y I 

Sector First 
Count Data 

Character 



The Disk Control Field determines the location in disk 
storage of the data to be used and determines the num- 
ber of disk sectors in the data record. The number of 
positions in core storage reserved for the data field 
must be large enough to contain all the data read from 
the disk. The group mark with a word mark at the end 
of the data field defines the total length of the area 
reserved. 

The Sector Count part of the disk control field speci- 
fies the number of disk sectors that are to be read or 
written by the instruction. 



The Core Sector Address part of the Disk Control 
Field contains the disk address of the data to be read 
or written. If more than one sector is read or written, 
the address of the first sector is specified. 

The disk address of the data indicates which storage 
drive is to be used by the system for an instruction, as 
shown in the examples below. 



Address Block 


Selects Disk Drive 


00000-19999 





20000-39999 


1 


40000-59999 


2 


60000-79999 


3 


80000-99999 


4 



If the disk address on a disk pack does not correspond 
to the number of the disk storage drive it is located on, 
then a Disk Alternate code is used. 

This coding provides the flexibility to operate upon 
any block of disk addresses, regardless of which disk 
drive the pack is located on, and, when the occasion 
requires, to have more than one Disk Pack containing 
the same disk addresses on-line at once. 

The selection of a particular Disk Storage Drive is 
made by using the following Alternate codes: 



Alternate Code 


Selects Disk Drive 








2 


1 


4 


2 


6 


3 


8 


4 



For example, if address block 60000-79999 is located 
on Disk Drive 4 (instead of Disk Drive 3) , the Alternate 
code in the Disk Control Field will be 8. 

When this flexibility is not required, the drive is 
selected directly from the core sector address and an 
asterisk (*) is placed in the Alternate Code part of 
the Disk Control Field. 



Write Disk Operation 

The Write Disk operation transfers data from core 
storage to disk storage. An area in core storage is set 
aside for the Disk Control Field, which specifies the 
disk storage drive to be used, the disk address where 
the data is to be written, and the number of sectors to 
be written on. 

The data to be transferred to disk storage is located 
immediately to the right of the Disk Control Field. If, 
for example, 100 character records are to be written 
into core storage, 110 core storage positions will be 
reserved; 9 positions for the Disk Control Field, 100 
positions for the data, and one position for a group 
mark with a word mark. 
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Write Disk Check Operation 

A Write Disk Check instruction must immediately 
follow each Write Disk instruction. The Write Disk 
Check operation causes the data just written in disk 
storage to be read and compared with the original 
source data in core storage. When the disk data does 
not compare, bit-by-bit and character-by-character, with 
the core storage data from which it was written, a Disk 
Error indicator is set. 

Scan Disk Operation (Special Feature) 

This feature provides the system with the ability to 
make a rapid search of a disk pack for a specific code 
or condition (such as data or account number) that 
is stored within the data itself. Only one seek and one 
scan disk instruction are required to cause the program 
to search through an entire cylinder (200 sectors) . The 
scan can be made to compare the search argument with 
the data, on the basis of the argument being low or 
equal to the data, equal to the data, or high or equal to 
the data. 

The program can be directed to scan (search) all 
records in a file, or all records in a cylinder, or any 
specific number of records. The Disk Control Field 
contains the address of the sector where the scan is to 
begin and the maximum number of sectors to be 
scanned. 

Four Modes of Read or Write Disk Operations 

Read instructions and Write instructions have four 
modes: 

Address Mode 
Sector Mode 
Sector Overlay Mode 
Track Record Mode 

It is possible to transfer data, with or without word 
marks, in any of these modes. 

Address Mode 

This mode of operation allows sector addresses re- 
corded in disk storage to be changed. It transfers both 
data and disk sector addresses to and from the file, one 
complete track at a time. The sector count must be 
set to 020 (sectors are transferred in blocks of twenty) . 

The operation requires that the Disk Control Field 
contain an address of one of the sectors within the track. 
This address must be satisfactorily compared with its 
counterpart in disk storage before the transfer can take 
place. 

To write in the Address Mode, the Write Address 
key-light on the number Disk Storage Drive unit must 
be set to the on position. 



Sector Mode 

The Sector Mode is the normal mode of operation. 
Read and Write operations in the Sector Mode transfer 
data, but do not transfer disk sector addresses. The 
number of sectors to be handled within one operation 
is designated in the Sector Count part of the Disk Con- 
trol Field. 

Each sector is transferred only upon absolute com- 
parison of sector addresses in Disk Storage with those 
in the Disk Control Field. The Core Sector Address 
in the Disk Control Field is automatically increased 
by one for each sector transferred and thereby supports 
the comparison of successive sector addresses. Similarly, 
the Sector Count is reduced by one and indicates by 
a 000 setting that the required operation has been com- 
pleted. 

If a group mark with a word mark is sensed in the 
Record field before the sector count reaches zero, the 
operation is terminated. Likewise, if the sector count 
reaches zero before the group mark with a word mark 
is sensed, the operation is terminated. Either of these 
events will result in the Wrong Length Record indi- 
cator being turned on. 

The Wrong Length Record indicator is tested by a 
Branch If Indicator On instruction. It is reset by the 
next Disk operation. 

Sector Count Overlay Mode 

The Sector Count Overlay mode of operation allows 
a record to indicate the number of sectors it contains 
by modifying the Sector Count portion of the Disk 
Control Field. This technique permits better utiliza- 
tion of disk storage in sequential-type applications 
having variable size records. In all cases, the variable 
size records must be in increments of 100. 

When such a record is read into the processing unit 
in the Sector Count Overlay Mode, the first data char- 
acter transferred from disk storage is stored in the 
leftmost position of the Sector Count part of the Disk 
Control Field instead of the position immediately to 
the right of the Disk Control Field. When a record is 
stored in disk storage from core storage, the trans- 
mission of data starts with the leftmost position of the 
sector count field. 

In the normal operation of read and write instruc- 
tions, the Sector Count in the Disk Control Field is 
decremented by one each time a sector is read from or 
written into the file. At the same time the Sector Ad- 
dress in the Disk Control Field is incremented by one. 
The operation is stopped when the sector count reaches 
zero. Incrementing and decrementing are automatic 
functions of the processing unit. 
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Initially, the Sector count must be set to a number 
greater than 001 before a read operation in the Sector 
Count Overlay mode is executed. The Sector Count 
Overlay mode cannot process records containing only 
one sector. 

Track Record Mode (Special Feature) 

Normally one 100-character record is written in or read 
from each of the 20 sectors of a track. The Track 
Record mode makes it possible to read or write one 
record in place of the twenty sectors of a track. This 
record consists of a 5-position address and 2980 posi- 
tions of data. The Track Record mode can also be used 
in the address mode to transfer the 5-digit address with 
the data. 

Reading and Writing with Word Marks 

In all reading and writing operations, the data to- 
gether with word marks may be read from, and written 
into, disk storage. When word marks are written on 
the file, the data is written in 8-bit bcd coding. The use 
of 8-bit coding reduces the number of characters that 
can be stored on a sector from 100 to 90, and reduces 
the total number of characters on a disk pack from 
2,000,000 to 1,800,000. In the Track Record Mode, 
the maximum number of characters on one track is 
reduced from 2980 characters to 2682 characters. 

Fixed and Variable Length Records 

Fixed length and variable length records can be stored 
in disk storage. The sector mode is used to process 



fixed length records. The sector count of the Disk Con- 
trol Field in this mode is constant and indicates the 
number of sectors contained in the record. The Sector 
Count Overlay mode is used to process variable length 
records. In this mode, the record itself contains the 
sector count. Because each record can contain a dif- 
ferent sector count, the length of each record can be 
variable. 



Format of Disk Storage Statement 

The disk storage statement takes the following form. 



Label 

6 IS 


Operation 

16 20 


21 25 50 35 


1 , , . 


OP, . 


AD,D.R 









where op is one of the disk mnemonic operation codes 
and ADDR is the address of the leftmost position of the 
Disk Control Field used in the operation. 

The mnemonic operation code to be used for all 
seek operations is: 

SK (Seek Disk) 

Read, Write, and Write Disk Check mnemonic op- 
eration codes are shown by mode in Table 3. 

The Scan Disk (special feature) mnemonic opera- 
tion codes are given in Table 4. 



Table 3. Mnemonic Operation Codes Used for Read, Write, and Write Disk Check Operations by Modes 





Modes 


Operation 


SECTOR 

(data 
only) 


ADDRESS 

(data and 
addresses) 


SECTOR OVERLAY 

(data and 
sector count) 


TRACK RECORD 
(special feature) 


data 
only 


data and 
addresses 


READ DISK 












without WM* 


RD 


RDT 


RDCO 


RDTR 


RDTA 


with WM 


RDW 


RDTW 


RDCOW 


RDTRW 


RDTAW 


WRITE DISK 












without WM 


WD 


WDT 


WDCO 


WDTR 


WDT A 


with WM 


WDW 


WDTW 


WDCOW 


WDTRW 


WDTAW 


WRITE DISK CHECK 












without WM 


WDC 


WDC 


WDC 


WDC 


WDC 


with WM 


WDCW 


WDCW 


WDCW 


WDCW 


WDCW 



*WM = Word Mark 
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Table 4. Mnemonic Operation Codes for the Scan Disk Operation 
This operation compares the Argument to the Data for one of the conditions shown in this table 



Operation 


Condition 


Low or Equal 


Equal 


High or Equal 


SCAN DISK 
(Special Feature) 

without WM 

with WM 


SDL 

SDLW 


SDE 
SDEW 


SDH 
SDHW 



o 



Disk Check Indicators 

Several disk check indicators provided on the 1440 
system are automatically turned on to indicate disk 
storage conditions or errors. It is up to the programmer 
to test the indicators in his program to identify the 
condition or error and to specify the course of action 
to be followed by his program. 

A description of the six disk check indicators follows. 



Any Disk Condition 

This indicator is set in unison with any other disk check 
indicator. It is reset by the next programmed disk 
storage operation. It can be tested by a Branch If 
Indicator On instruction. 

Access Busy 

This indicator is set when reference is made to a Disk 
Storage -Drive that is in a Busy status. The programmed 
disk operation is terminated. The indicator is tested 
by a Branch If Indicator On instruction. It is reset 
upon completion of the next programmed disk stor- 
age operation. 

Access Inoperable 

This indicator is set when reference is made by a disk 
operation to a Disk Storage Drive that is in a Not 
Ready status. Because the access is in a Not Ready 
status, the disk operation is terminated. 

The Access Inoperable indicator is tested by a Branch 
If Indicator On instruction. It is reset by the next 
programmed disk storage operation. 

Disk Error 

This indicator is set when a parity error is detected 
during a Read or Write Disk operation, or when an 
Unequal Compare or parity error occurs during a 
Write Disk Check operation. The indicator is tested 
by a Branch If Indicator On instruction. It is reset 
by the next programmed disk storage operation. 



Wrong Length Record Check 

This indicator is set when a 000 Sector Count and the 
group mark with a word mark fail to correspond at the 
end of a Read or Write or Disk Check operation. This 
indicator is also turned on if data records read from 
disk storage or written to disk storage are not in even 
increments of 100 characters. The indicator is tested 
by a Branch If Indicator On instruction. It is reset by 
the next programmed disk storage operation. 

Unequal Address Compare 

This indicator is set (1) if a disk data transfer is 
initiated and the sector address does not compare and 
(2) after the data transfer process begins, if the next 
sector address in physical sequence fails to compare, i.e., 
the sector address of the Disk Control Field and the 
next disk address are unequal. The indicator is tested 
by a Branch If Indicator On instruction. It is reset by 
the next programmed disk storage operation. 

Format of Branch If Indicator On Instruction 

The Branch If Indicator On instruction can be used 
to test any of the indicators contained in the system. 
Included in these indicators are the six Disk Check 
indicators. The instruction used to test these indicators 
takes the following form 



g 


Lobel 


15 


Operation 

16 20 


21 25 


30 


35 


, , , , t 1 . , . 


BIN. 


I NST ..d 









where BIN is the actual mnemonic operation code, 
INST is the address of the instruction which the pro- 
gram branches to if the indicator is on, and d is the 
d-modifier character which identifies the indicator to 
be tested. A list of the d-modifier characters that can 
be used with this instruction is given in Table 5. 
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Table 5. d-modifier Characters Used with Branch If Indicator On Operation 







d-modifier 
character 


Indicator 


Reset by 


bl 


Unconditional 


Branch 


9 


Carriage Channel 9 


Branch Test 


@ 


Carriage Channel 12 


Branch Test 


A 


"Last Card" Switch 
(Sense Switch A) 


Manual 


B 


* Sense Switch B 




C 


* Sense Switch C 




D 


* Sense Switch D 




E 


* Sense Switch E 




F 


* Sense Switch F 




G 


* Sense Switch G 




N 


Access Inoperable 


Next Disk Storage operation 


\ 


Access Busy 


Next Disk Storage operation 


P 


Printer Busy 




/ 


Unequal Compare (B 7^ A) | 




S 


Equal Compare (B = A) I 


Next Compare or 


T 


Low Compare (B < A) 




Disk Storage operation 


U 


High Compare (B > A) j 






V 


Disk Error ^ 






w 


Wrong Length Record 




Next Disk Storage Operation 


X 


Unequal-Address GDmpare 






Y 


Any Disk Condition ^ 






z 


Overflow 


Branch Test 


% 


Processing Check with Process 
Check Switch off 


Branch Test 


? 

! 


Read Error ^ ,^ ,/q ^^^^^ 3^^^ 1 

Punch Error > 5^; ^^^ Is off ' 
Printer ErrorJ ^ 


Reset by Test; must 
be reset before next 
operation 



Special Feature 



Testing the Disk Check Indicators 

The programmer should always test the Access Busy 
indicator after the first disk (seek, read, write, etc.) 
instruction following a seek. If this test is omitted, the 
disk instruction which follows the seek can be negated 
(not acted upon) without being detected. If this in- 
dicator is on when tested, it means that the disk in- 
struction was negated. The program can then be in- 
structed to branch back to repeat the negated disk 
operation. If the indicator is off when tested, the pro- 
gram may proceed with the next instruction, for the 
test indicates that the disk operation has been per- 
formed. 

The Any Disk Condition indicator makes it possible 
to make one check for any disk errors, and if the in- 
dicator is off, to proceed with the normal program. 



If the indicator is on, only then is it necessary to test 
the other indicators to find out which error condition 
is present. A good practice in coding a disk operation 
is to follow it always by a test of the Any Disk Condition 
indicator. 

The programmer can write one subroutine to test the 
indicators and use this common subroutine after every 
disk operation, and thus save program storage space. 
In such a subroutine, it is desirable to have a program 
loop which will cause the disk operation to be re- 
peated (up to three times) if the Disk Error indicator 
is on. By repeating the operation, the error in some 
instances may be corrected automatically by the com- 
puter without operator intervention, thus saving 
valuable computer time. 
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For the other indicators (Access Inoperable, Wrong 
Length Record, or Unequal Address Compare) it may 
be desirable to halt the program if any of these is on. 
The program should then try to re-execute the disk 
storage operation when the Start key is depressed. It 
should be noted that an on condition of the Unequal 
Address indicator can be caused by a cylinder overflow; 
L.e., by attempting to read or write beyond the capacity 
of a cylinder. In some applications, the programmer 
may want to write beyond the capacity of a cylinder. 
If he does he must give another seek instruction to get 
to the next cylinder; and then, a second read or write 
instruction to continue the operation which initially 
caused the cylinder overflow. 



Programming Example 5. 
Storing Records in Disk Storage 

In Programming Example 5, we will read name and 
address data from cards, two cards for each address, 
and store the name and address record in disk storage. 
We will use a control field from the card for direct 
addressing, that is, use the control field as the sector 
address. Figure 27 shows the format of input cards. 
Customer number, which will also become the direct 
address, is the same number in both cards. Codes 1 and 
2 in column six identify the first and second cards of a 
name and address record. 



In Figure 28A, block diagram, and Figure 28B, 
decision table, we can see that the card code determines 
the course of action to be followed in the program. 
Card code 1, the customer name and address part of the 
record, is assembled and a seek instruction is initiated. 
Card code 2, the city and state part of the record, is 
assembled and the disk record is written into disk stor- 
age from core storage. Figure 29 is a record layout 
which corresponds to the 100 characters of a sector. 

The Write Disk operation is followed by a Write 
Disk Check operation, as it must be. Note that certain 
parts of the disk control field are changed when the 
write command is given; the sector address is incre- 
mented by one and the sector count is decremented by 
one. Therefore, the disk control field must be restored 
to its original value before the Write Disk Check can 
be given. The Any Disk Condition indicator is tested 
following the Write Disk Check operation. If it is on, 
the program halts. The program would not halt at this 
point if we had inserted in our program a subroutine 
for testing the individual indicators, as described 
earlier. 

Figure 30 is the program coding sheet. First, a card 
reading area (66 positions) and disk record area (100 
positions) , each followed by a group mark with a word 
mark, are defined in core storage. The disk control field, 
defined by a DCW statement, immediately precedes the 



() 



\ / 





/ 


CUST NO 


8 


CITY & STATE 












00000 

t 2 3 4 5 




6 




7 8 9 10 1112 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 


00000000000 000000000000000000000000000000000 1 

37 38 33 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 68 67 68 69 70 71 72 73 74 75 76 77 78 79 80 1 


/ 


CUST NO 


8 

U 


CUSTOMER NAME 


ADDRESS 


00000000000000 

67 68 69 70 71 72 73 74 75 76 77 78 79 80 
11111111111111 

22222222222222 
33333333333333 
44444444444444 
55555555555555 
66666666666666 
77777777777777 
88888888888888 
99999999999999 

67 68 69 70 71 72 73 74 75 76 77 78 79 80 


79 80 




00000 

12 3 4 5 
111 11 

22222 
33333 
44444 
55555 
66866 


4 


00 000000 00 000000 000 00 00 00 000 

7 • 9 10 11 12 13 14 15 ie 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 
111111111111111111111111111111 

2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 
33333333333333333333 33 333333 33 
444444444444444444444444444444 
555555555555555555555555555555 
666666666666666666666666666666 


000000000000000000000000000000 

37 383940 4142 43 444546 47 48 49 50 515253545556 57 585960 616263646566 
111111111111111111111111111111 

2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 
3333333 3333 33333 33 333333333333 
444444444444444444444444444444 
555555555555555555555555555555 
666666666666666666666666866666 


77 
88 
99 

1 2 


77 7 
1188 
999 

3 4 5 


7 8 91( 


7 
8 

9 

11 


7777777777777777777777777 
8888888888888888888888888 
9999999999999999999999999 

12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 


77777 
88888 
99999 

37 38 39 40 41 


7777777777777777777777777 
8888888888888888888888888 
9999999999999999999999999 

42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 





Figure 27. Name and Address Cards for Storing Records in Disk Storage 
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Read Card 




Move Disk 
Address and 
Sector Count to 
Disk Control Field 




Move 

City and State 

to Record 



Seek 



Move 

"Customer No, 
Nome, Address, 
to Record 





Halt 



Write 

Disk 

Check 



Off 




Halt 



Figure 28A. Block Diagram for Storing Records in Disk Storage 



record-defining statements. This arrangement of state- 
ments is necessary to assign the disk control field the 
nine positions to the immediate left of the 100-position 
record area. Note that records are written in the sector 
mode; therefore, the sector mode operation code 
mnemonics are used. 



Programming Example 6. 

Printing Name and Address Labels 

from Disk Storage 

This problem may be considered an extension of the 
previous one where we loaded name and address rec- 
ords into disk storage. Here, we will use the finder cards 
which contain the customer number (direct disk ad- 
dress) in columns 1-5 to select the disk records to be 



*♦ START 












n 






'^ 






N 


y 


















2 1 READ CARD 


X 


■ 


















3 1 GO TO TEST CARD CODE 


X 




















4 1 GO TO END OF JOB HALT 




X 








































*'^ TEST CARD CODE 






















1 1 CARD CODE EO 1 


Y 


n|n 
















2 t CARD CODE EQ 2 


N 


YJN 


































3 1 SET CORE SECTOR ADDR EQ CUST.NO. 


X 




















4 1 SET SECTOR COUNT EQ 001 


X 




















5 ! MOVE GUST . NO . , NAME , ADDR TO 






















IrECORD: CORE 


X 




















6 'MOVE CITY. STATE TO RECORDtCORE 




X 


















7 'WRITE RECORDtCORE TO DISK 




X 


















8 |DO TEST DISK INDICATORS 




X 
















9 SET SECTOR COUNT EQ 001 




x^ 
















10 1 WRITE CHECK RECORD: DISK 




i 
X 














11 1 DO TEST DISK INDICATORS 


__|Xl 
















12 J GO TO START 


X 


X 
















13 IgO TO ERROR HALT 






X 




























































1 lARE ANY DISK INDICATORS ON ? 


N 


Y 


Y 
















2 !IS ACCESS BUSY INDICATOR ON ? 




y 


N 






































3 IWRITE RECORD TO DISK AGAIN 




X 
















4IHALT 






fx 
















5 [RETURN 


X 


X 






















1 

















Figure 28B. Decision Table for Storing Records in Disk Storage 



printed. The format of the disk record will be the 
same as it was in the last example (Figure 29) . 

Figure 31 shows the format for the three name and 
address labels that are to be prepared simultaneously 
from one record. The channel 1 punches in the carriage 
control tape are used for carriage skipping to the first 
line of the addresses. 

In Figure 32A, block diagram, and Figure 32B, 
decision table, note that the address (customer num- 
ber) in each card is used to select the record. After 
the record is read into core storage, the customer num- 
ber in the record and the customer number in the finder 
card are compared to see if they are equal. 



h 5^ 



3536 



5[36 65|66 95[ lOol 

"1 Address I City and Sfate I I 



Cust I Customer 
No Name 



Figure 29. Record Layout for Storing Records in Disk Storage 
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Page 


No.|0,l| of 2 

1 2 


Line 
3 5 


Label 
6 rs 


Operation 

16 20 


OPERAND 

21 25 30 35 40 45 50 55 60 65 70 


2 


i^dare.aI 


DA 


ix,6,6,,.G d,e.f,in;e, ,qa,r,d, .re^adijstg AR.EA 


cusx^ocl 










L ..5 






L„ 


. , ,C,U,ST,OM,E,R. ,N,UMRE,R 








3 


CQDE.C. 1 














6 








. . ,C.O,D.E 








0,4 


NAMEQ 1 














7,, ,3,6, .,,,,. 








. , ,NA,ME. ,0,R, .C,I,T,Y, ,&, g,T,A.XE 








0,5, 


Ai^D,R,c. ; 














3,7,, ,6,6. 








. , AX),DJl£S3, J 








0,6 




ds,k,c,tf1 








DCW 






a*ti 15 15 ;fet», 0,0.1.(3 






D 


I.S,K, ,C.O.NTK,0,L. ,F,I,E,LJ), ,C,O.N. S, T, ANT. , 








0,7 




11 1 1 1 i 








D,A 






l,x, 1,0,0,, ,G, , , . 






P 


E.F,I.N.E, .E|I,SK:, .R,E.C,0,R.D 








0,6 




C,U,SJ^,Ofll 














5 








. , ,c,u,stp,m.e,r. ,NqM:3^i^ . , 








9 




^A^^^ \ 














3,5 








. , ,n,ame; , _ 








1 




AEiD.RR. 1 














6.5 








. , .ADQKKS.S 








1 1 




c, i,t,y.s.r! 














9,5 








. , ,C,I,T.Y, ,&, ,S.TA,T,E , 








\^Z 




START. ! 








R , 






1,, ,R.D,A.RE,A, , , 








.r.ea.d .ca,kd 




^,^^_^^... 


._._. 


',3 












B.C^ 






c,a,r,d.i., ,c,o,d,e.c 


» 


1 




,qA^D, .C,0,D,E, ,1. ,? 


1 ,4 
1,5 


- 










BCE 






C,AR.D,2.,.CAD>E.C 




2 




.CA.R,D .C,0,D,E, .2, ,? , , , . , 
















H 






START 








.hal.t .f,o,r, ,i .n.v.ali.d code 








1 ,6 




CARQl. i 








MLG 




C,U,SND£,.,D,SKC 


?* 


F 


_ 


3. , M.O.V.E. .DISK, ,ADD.RE,S,S, .XQ DI .SJC 




C,T.R,L, ,F,I 


LP 


1 ,7 












Mi;^i^s 




@i,@,.P.s,k;c,t,f. 








. JV[,0,V.E, S,E;C,T,0,^ ,CPUN.T, .TO, ,DI,SK 




C,T,RL F,I 


LD 


'.8 












S,D , 




DS,KC,TF,-,8, , . 








. , .SEEK, , , . . 








<,d 




' ' ■ i t 1 








MLC 




NA,ivtE,c. .,ha,me;r 








. , ,M,O.V.E, ,C,U,S.T,0,ME,R, .KAM^ ,AND . , 






^- 


2 












MX^Q 




AD.D.R,C.,,A,D,D,R.R 








. , , .AD.D,R,E,S,S. ,T,Q R,ECAR,D 




S,TA,R,T, , 


2, 1 












5 , 




S,TAP,T 








, , , BRANCH .U.N,C.O,N,D.I.TJP,NA.L,L,Y, .T.O 


2,2 




CARr)2. ; 








MLC 




n;ameg.c,i,t,y.s 


R 






, , ,MO,V.E, .C, I.T.Y, ,&, ,S,T,AT,E, .T.O, ,RE.C,0 


I^D, 




2.3 




W^I,TE. 1 






WD , 




E>S,K^C,T.F-,8 , . 








. , .W,R,I.T,E, .D,I.S,K. ,R,E.C,ORD 






2,4 




,11:. 




B I N 




WmTE.,,\ . , . 






L- J 


i , , BRANCH ,IF, AC.CE.SS B.U 3 Y , . , 






2,5 






M1^N.S, 


(^,1.(^.,.K,S,1^C,T,F, 






. K-P,T,0,R,E, ,D.I^^, ,C.ONT,R,0,L, ,FIE,LD 


'::;:;,,. i 



i) 



Page No.Uij2J of 



JI^ 



A 

y 



Line 
3 5 


Label 

6 15 


Operation 
16 20 


OPERAND 

21 25 30 35 40 45 50 55 60 fifi 7n 


0. ( , 


1 
> I i . 1 1 






A , , , 


(ai,<3,,D.S 


i^CX 


Z 


-,3 










2, 


i 






WDC , 


DS.KCT.F 


-,8. 












,C,H,E,C.K. .PI.S.K, .W,R,IX,I N,G. 








0,3 


. . I I . i 






BJ,N, 


D,S,KE,R.R 


1.Y, 






1— 






,BJl,A,NCH X,F, A, NY, ,E,R,R,0,R. 








0,4 


; 






BI.G , 


L,STCD. 














T,EST. ,Fp,R, ,L,A,S,T, ,C,ARD^ 








0,5, 


1 







B, , . , 


S.XAHT. 














.BRAN.CH ,UNCO:N,DLXI,ONA,LLY T.O 


START 






0,6, 


PSKE^H^ 


1 — 1 




H , , , 


S T,A,R,X 














,HA,LT. ,F,OR, P.I ,S K^ .ERROR 








0,7, 


LST.CD. 1 






H , , , 


S ,T.ART. 














,HA,L,X ,F,QH .I.ASX, .C,A,R,D 








T?;rr,,^ 


^ an r',r^^;«^ 


, c 


u^^ 


t^^ f^^ c*^^^ 


;*,™ T>«^^ — J 























Figure 30. Coding Sheets for Storing Records in Disk Storage 






38 



o 



^iK 



8^^^4-4-4- 



M-4 



FROW 

GENERAL MANUFACTURING CO. 

ENDICOTT, N.Y. 



DELIVER TO 

ROGER CARR 

1132 N EDDY STREET 

SANTA CLARA, CALIF. 



PROK 
GENERAL MANUFACTURING CO. 

ENDICOTT, N.Y. 



DELIVER TO 

JOHN PAGE 

1682 FLORENCE DRIVE 

EAU CLAIRE, WISC. 



PROM 

GENERAL MANUFACTURING CO. 

ENDICOTT, N.Y. 



DELIVER TO 

LARRY SHAMUS 
2121 JOHNSTON WAY 
SAN JOSE, CALIF. 



FROM 

GENERAL MANUFACTURING CO, 

ENDICOTT, N.Y. 



DELIVER TO 

JAC WYMAN 

1358 EARL AVENUE 

ENDICOTT, N.Y. 



FROM 
GENERAL MANUFACTURING CO. 
ENDICOTT, N.Y. 



DELIVER TO 

ROGER CARR 

1132 N EDDY STREET 

SANTA CLARA, CALIF. 



FROM 

GENERAL MANUFACTURING CO. 

ENDICOTT, N.Y. 



DELIVER TO 

JOHN PAGE 

I682 FLORENCE DRIVE 

EAU CLAIRE, WISC. 



FROM 

GENERAL MANUFACTURING CO. 

ENDICOTT, N.Y. 



DELIVER TO 

LARRY SHAMUS 
2121 JOHNSTON WAY 
SAN JOSE, CALIF. 



-h- 



FROM 
GENERAL MANUFACTURING CO. 

ENDICOTT, N.Y, 



DELIVER TO 

JAC WYMAN 

1358 EARL AVENUE 

ENDICOTT, N.Y. 



FROM 
GENERAL MANUFACTURING CO, 
ENDICOTT, N.Y. 



DELIVER TO 

ROGER CARR 

1132 N EDDY STREET 

SANTA CLARA, CALIF. 



FROM 

GENERAL MANUFACTURING CO. 

ENDICOTT, N.Y. 



DELIVER TO 

JOHN PAGE 

1582 FLORENCE DRIVE 

EAU CLAIRE, WISC. 



FROM 

GENERAL MANUFACTURING CO. 

ENDICOTT, N.Y. 



DELIVER TO 

LARRY SHAMUS 
2121 JOHNSTON WAY 
SAN JOSE, CALIF. 



FROM 
GENERAL MANUFACTURING CO. 
ENDICOTT, N.Y. 



DELIVER TO 

JAC WYMAN 

1358 EARL AVENUE 

ENDICOTT, N.Y. 
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Figure 31 . Form Layout for Printing Name and Address Labels from Disk Storage 
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Halt 
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Assemble 
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Assemble 
Second Line 
of Tliree Labels 



t: 



Print 



LrC 



Assemble 

Third Line 

of Three Labels 



Print 



L^: 



Skip to 
Channel One 
of Carriage 
Control Tape 




Print 



Figure 32A. Block Diagram for Printing Name and Address 
Labels from Disk Storage 



This check also verifies that the right record was read. 
In all disk read operations it is good programming 
procedure to have some field o£ data in the record such 
as part number or customer number, which can be 
compared to a given field to verify that the correct 
record was read. 



♦♦START 






















1 |HAS LAST CARD BEEN PROCESSED? 
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2 iREADflARn 
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3 IsET CORE SECTOR ADDR EQ CUST. NO. 


X 




















4 |SET SECTOR COUNT EQ 001 


X 




















5 |GET CUSTOMER RECORD: DISK 


X 




















6 iDO TEST DISK INDICATORS 


X 




















7 jDO COMPARE CUSTOMER NO. 


X 




















8 1 PRINT TAREKS 
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9 IgO TO START 
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10 |CK)TOHALT 
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♦♦ItEST DISK INDICATORS 






















1 lARE ANY DISK INDICATORS ON ? 
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Y 


y 
















2 IIS ACCESS BUSY ON ? 


N 


Y 


N 
















3 'GET CUSTOMER RECORD: DISK AGAIN 




X 


















4 |HALT 






X 
















5 Ireturn 


X 


X 








































♦♦ICOMPARE CUSTOMER NO. 






















1 |CUST. NO: CARD VS CUST. NO. DISK 
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£ 


















2 iHALT 




X 









































Figure 32B. Decision Table for Printing Name and Address 
Labels from Disk Storage 



In this programming example, we could have printed 
the name and address labels for each customer, one 
after the other, rather than printing the three at one 
time. However, more computer time would have been 
used to do it this way. Often, it is advantageous to print 
copies side by side when the printing capacity allows 
such operation. Figure 33 is the coding sheet for this 
program. 

Programming is the process of preparing a logical 
set of instructions for the computer to follow. There 
are many programming systems in existence; Autocoder 
is but one. Since the 1440 uses Autocoder, we have ex- 
plored this particular programming system in this 
book. 

Not all functions of the 1440 Data Processing System 
or of the Autocoder programming system are explored 
nor are the programming solutions in this book the 
only acceptable ones. But we have presented the funda- 
mentals which will allow the student programmer to 
go on to attempt to program a greater variety of jobs 
and more difficult jobs. 

If possible, the student programmer should work 
with an experienced programmer in developing the 
first few programs. If not, he should get the help of an 
experienced programmer and get him to check the 
accuracy of his programs. In the end, though, it is 
practice that counts. 
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Figure 33. Coding Sheets for Printing Name and Address Labels from Disk Storage 



Programming with Disk Storage 61 



Section 5. Questions 

1. List two other items, besides data records, that 
could be stored in disk storage. 

2. Is it true that the sequential storage method of 
storing records offers the advantage of unlimited 
storage capacity? 

3. List the three parts of the disk control field. 

4. An area of core storage reserved for reading a 
disk record must be followed by a group mark 
with a word mark and immediately preceded by 

a. an asterisk. 

b. the disk control field. 

c. a group mark with a word mark. 

5. After a disk record is read into an area of core 
storage from disk storage, what are the two changes 
that must be made to the disk control field before 
the record can be written back to its original loca- 
tion in disk storage? 

6. If a disk pack containing address block 00000- 
19999 is located on disk drive 2 instead of disk 



drive 0, the disk alternate code in the disk control 
field should be 

a. zero 

b. eight 

c. twelve 

d. four 

e. seven 

7. Write an instruction which will test the Unequal 
Address Compare indicator and, if it is on, branch 
to the instruction labeled test. 

8. The Access Busy indicator must be tested 

a. only once during a program. 

b. after every disk operation. 

c. after a disk read or write operation. 

d. after the first disk (seek, read, write, etc.) in- 
struction following a seek instruction. 

9. The number of tracks within a disk cylinder is 

a. 100 

b. 10 

c. 1000 

d. 99 



o 
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Appendix 



Section 7 . Answers and Solutions 

1. 1443 Printer 

2. Yes. All data goes through the processing unit. 

3. Yes. Data from the processing unit may be moved 
as output to any one output device or any com- 
bination of output devices. 

4. 4000 characters 

5. A card must pass the reading station before it 
can be punched. 

6. a. Control b. Storage c. Arithmetic 

7. 90 characters with word marks 
100 characters without word marks 

8. 20,000-20,199 (address range) 

9. Disk Sector address 

10. Yes. Each position of core storage has a unique 
address. 

11. To identify the leftmost position of a data field. 



Section 2. Answers and Solutions 

1. a. Establish the requirements of the problem and 
the requirements of the solution. 

b. Write the program for the computer to follow. 

2. Autocoder. 

3. b. To assign storage areas for data. 

4. a. The leftmost position of the area reserved. 

5. b. The address of the rightmost position of the 

constant. 

6. To specify that the constant is alphameric, 

7. The leftmost position of the first constant will 
be given a word mark by the processor, whereas, 
the second constant will contain no word mark. 

8. 



Label 

6 15 


Operation 

16 20 


21 25 30 55 40 


C,QN,S,T.l| . , . 


DCW, , 


@ERRO.R. .L,I.S.T,IJ^.G @, , , , 


F.Oy,RT.Hl , 


Df;,w. . 


1 2,.3.4,.'i.6 














DATE, . 1 . , . 


DC, , . 


!a, nRG ,9, .0, , 
















A, , . , 


2, 9, 6, 2, ,.7, 2.0, , . 














REA,D,IJ^1 , . , 


DA, , . 


IX.8,0 














DATE, . 1 . . , 


DCW. , 


@.FE.HRU.AR.Y,@. 

































Section 3. Answers and Solutions 

1. d. is passing the reading station. 

2. c. DA (Define Area) operation code. 

3. 49 positions of core storage are required: 48 posi- 
tions are used for data and a 49th position con- 
tains a group mark with a word mark. 

4. Answers a and b are both positive. 

B 

a. A equals plus 2 
2 

b. -equals plus 2 

5. c. both fields must contain a word mark in their 
leftmost position. 

6. c. a branch to the address of the instruction 
specified by line 01 can be performed by a later 
program step. 



Section 4. Answers and Solutions 

1. d. MLCWA (Move Characters and Word Mark 
from A Eield) . This operation moves the word 
mark along with the edit control word to the print 
field. The word mark is required in the control 
word for editing. 

2. Fields after edit 

$t5bbbb.0l- 

$6,436.25 

3. c. can appear before or after the printing instruc- 
tion. If the CC instruction appears before the 
print instruction, a skip-after-printing d-modifier 
is used. If the CC instruction appears after the 
print instruction, an immediate-skip d-modifier 
is used. 

4. No. 

5. a. is not true. 

6. No; a CC instruction must be executed to provide 
the skip. 
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8. b. STEPX. 
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11. b. sets an indicator which may be tested by sub- 
sequent instructions. 

12. a. Unequal 

b. Equal 

c. Unequal 

d. Unequal 

13. 
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Section 5. Answers and Solutions 

1. a. program instructions 
b. tables 

2. Yes 

3. a. access code 

b. core sector address 

c. sector count 

4. b. the disk control field 

5. On the read operation the core sector address was 
incremented by the number of sectors read and 
the sector count was decremented to zero. The 
core sector address and sector count must be re- 



stored to their original values before the record 
can be written back to disk storage. 

6. d. four 

7. 
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8. d. after the first disk (seek, read, write, etc.) in- 
struction following a seek instruction. 

9. b. 10 tracks 
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